当前位置:首页 > CN2资讯 > 正文内容

我的世界Java坐标怎么常驻

2天前CN2资讯


Day21(IO流之字符流)

字符流

字符流的概述

A:字符流是什么? *字符流是可以直接读写字符的IO流; *字符流读取字符,就要先读取到字节数据,然后转换为字符.如果要写出字符,需要把字符转换为字节写出 B:FileReader *FileReader类的read()方法可以按照字符大小读取 public static void main(String[] args) throws IOException { FileReader fr = new FileReader("xxx.txt"); int c; while ((c = fr.read()) != -1) { // 通过项目默认的码表一次读取一个字符 System.out.print((char) c); } fr.close(); }

FileWriter

public static void main(String[] args) throws IOException { FileWriter fw = new FileWriter("yyy.txt"); fw.write("好好学习,天天向上!!!"); //通过编码表翻译 fw.write(97); fw.close(); }

字符流的copy

public static void demo1() throws FileNotFoundException, IOException { FileReader fr = new FileReader("xxx.txt"); FileWriter fw = new FileWriter("zzz.txt"); int c; while((c = fr.read()) != -1) { fw.write(c); } fr.close(); fw.close(); //Writer类中有一个2k的小缓冲区,如果不关流,就会将内容写到缓冲区里,关流会将缓冲区内容刷新,再关闭 }

什么情况下使用字符流

* 字符流也可以拷贝文本文件, 但不推荐使用. 因为读取时会把字节转为字符, 写出时还要把字符转回字节. * 程序需要读取一段文本, 或者需要写出一段文本的时候可以使用字符流 * 读取的时候是按照字符的大小读取的,不会出现半个中文 * 写出的时候可以直接将字符串写出,不用转换为字节数组

字符流是否可以非纯文本文件

* 不可以拷贝非纯文本的文件 * 因为在读的时候会将字节转换为字符,在转换过程中,可能找不到对应的字符,就会用?代替,写出的时候会将字符转换成字节写出去 * 如果是?,直接写出,这样写出之后的文件就乱了,看不了了 public static void demo2() throws FileNotFoundException, IOException { // 字符流不能拷贝纯文本的文件 FileReader fr = new FileReader("周冬雨.jpg"); FileWriter fw = new FileWriter("copy.jpg"); int c; while ((c = fr.read()) != -1) { fw.write(c); } fr.close(); fw.close(); }

自定义字符数组的copy

FileReader fr = new FileReader("aaa.txt"); //创建字符输入流,关联aaa.txt FileWriter fw = new FileWriter("bbb.txt"); //创建字符输出流,关联bbb.txt int len; char[] arr = new char[1024*8]; //创建字符数组 while((len = fr.read(arr)) != -1) { //将数据读到字符数组中 fw.write(arr, 0, len); //从字符数组将数据写到文件上 } fr.close(); //关流释放资源 fw.close();

带缓冲的字符流

* BufferedReader的read()方法读取字符时会一次读取若干字符到缓冲区, 然后逐个返回给程序, 降低读取文件的次数, 提高效率 * BufferedWriter的write()方法写出字符时会先写到缓冲区, 缓冲区写满时才会写到文件, 降低写文件的次数, 提高效率 * BufferedReader br = new BufferedReader(new FileReader("aaa.txt")); //创建字符输入流对象,关联aaa.txt *BufferedWriter bw = new BufferedWriter(new FileWriter("bbb.txt")); //创建字符输出流对象,关联bbb.txt int ch; while((ch = br.read()) != -1) { //read一次,会先将缓冲区读满,从缓冲去中一个一个的返给临时变量ch bw.write(ch); //write一次,是将数据装到字符数组,装满后再一起写出去 } br.close(); //关流 bw.close();

readLine()和newlLine()方法

* BufferedReader的readLine()方法可以读取一行字符(不包含换行符号) * BufferedWriter的newLine()可以输出一个跨平台的换行符号"\r\n" * newLine()与\r\n的区别 * newLine()是跨平台的方法 * \r\n只支持的是windows系统 public static void demo1() throws FileNotFoundException, IOException { BufferedReader br = new BufferedReader(new FileReader("zzz.txt")); String line; while ((line = br.readLine()) != null) { System.out.println(line); } br.close(); } public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new FileReader("zzz.txt")); BufferedWriter bw = new BufferedWriter(new FileWriter("aaa.txt")); String line; while ((line = br.readLine()) != null) { bw.write(line); // bw.newLine(); // 写出回车换行符 bw.write("\r\n"); } br.close(); bw.close(); }

练习

/** * @param args * 将一个文本文档上的文本反转,第一行和倒数第一行交换,第二行和倒数第二行交换 * * 分析: * 1,创建输入输出流对象 * 2,创建集合对象 * 3,将读到的数据存储在集合中 * 4,倒着遍历集合将数据写到文件上 * 5,关流 * @throws IOException * * 注意事项: * 流对象尽量晚开早关 * 什么时候用,什么时候开,什么时候用完,什么时候关 */ public static void main(String[] args) throws IOException { //改写后是尽量晚开早关 // 1,创建输入输出流对象 BufferedReader br = new BufferedReader(new FileReader("zzz.txt")); //2,创建集合对象 ArrayList<String> list = new ArrayList<>(); //3,将读到的数据存储在集合中 String line; while((line = br.readLine()) != null) { list.add(line); } br.close(); //关流 //4,倒着遍历集合将数据写到文件上 BufferedWriter bw = new BufferedWriter(new FileWriter("revzzz.txt")); for(int i = list.size() - 1; i >= 0; i--) { bw.write(list.get(i)); bw.newLine(); } //5,关流 bw.close(); } }

LineNumberReader

* LineNumberReader是BufferedReader的子类, 具有相同的功能, 并且可以统计行号 * 调用getLineNumber()方法可以获取当前行号 * 调用setLineNumber()方法可以设置当前行号 public class Demo5_LineNumberReader { /** * @param args * @throws IOException */ public static void main(String[] args) throws IOException { LineNumberReader lnr = new LineNumberReader(new FileReader("zzz.txt")); String line; lnr.setLineNumber(100); while((line = lnr.readLine()) != null) { System.out.println(lnr.getLineNumber() + ":" + line); } lnr.close(); } }

装饰设计模式

public class Demo6_Wrap { /** * @param args * 装饰设计模式的好处是: * 耦合性不强,被装饰的类的变化与装饰类的变化无关 */ public static void main(String[] args) { SuperStudent sus = new SuperStudent(new Student()); sus.code(); } } interface Coder { public void code(); } class Student implements Coder { @Override public void code() { System.out.println("javase"); System.out.println("javaweb"); } } class SuperStudent implements Coder { // 1,获取被装饰类的引用 private Student s; // 获取学生引用(对象) // 2,在构造方法中传入被装饰类的对象 public SuperStudent(Student s) { this.s = s; } // 3,对原有的功能进行升级 @Override public void code() { s.code(); System.out.println("ssh"); System.out.println("数据库"); System.out.println("大数据"); System.out.println("..."); } }

使用指定的码表读写字符

* FileReader是使用默认码表读取文件, 如果需要使用指定码表读取, 那么可以使用InputStreamReader(字节流,编码表) * FileWriter是使用默认码表写出文件, 如果需要使用指定码表写出, 那么可以使用OutputStreamWriter(字节流,编码表) public static void demo2() throws UnsupportedEncodingException, FileNotFoundException, IOException { InputStreamReader isr = new InputStreamReader(new FileInputStream("utf-8.txt"), "uTf-8"); //指定码表读字符 OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("gbk.txt"), "gbk"); //指定码表写字符 int c; while((c = isr.read()) != -1) { osw.write(c); } isr.close(); osw.close(); } * BufferedReader br = //高效的用指定的编码表读 new BufferedReader(new InputStreamReader(new FileInputStream("UTF-8.txt"), "UTF-8")); BufferedWriter bw = //高效的用指定的编码表写 new BufferedWriter(new OutputStreamWriter(new FileOutputStream("GBK.txt"), "GBK")); int ch; while((ch = br.read()) != -1) { bw.write(ch); } br.close(); bw.close();

练习

/** * 获取一个文本上每个字符出现的次数,将结果写在times.txt上 * * 分析: * 1,创建带缓冲的输入流对象 * 2,创建双列集合对象TreeMap * 3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储 * 4,关闭输入流 * 5,创建输出流对象 * 6,遍历集合将集合中的内容写到times.txt中 * 7,关闭输出流 * @throws IOException */ import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.util.TreeMap; public class Test6 { public static void main(String[] args) throws IOException { // * 1,创建带缓冲的输入流对象 BufferedReader br = new BufferedReader(new FileReader("zzz.txt")); // * 2,创建双列集合对象TreeMap TreeMap<Character, Integer> tm = new TreeMap<>(); // * 3,将读到的字符存储在双列集合中,存储的时候要做判断,如果不包含这个键,就将键和1存储,如果包含这个键,就将该键和值加1存储 int ch; while ((ch = br.read()) != -1) { char c = (char) ch; /*if(!tm.containsKey(c)) { tm.put(c, 1); }else { tm.put(c, tm.get(c)+1); }*/ tm.put(c, !tm.containsKey(c) ? 1 : tm.get(c) + 1); } // * 4,关闭输入流 br.close(); // * 5,创建输出流对象 BufferedWriter bw = new BufferedWriter(new FileWriter("time.txt")); // * 6,遍历集合将集合中的内容写到times.txt中 for (Character key : tm.keySet()) { switch (key) { case '\t': bw.write("\\t" + "=" + tm.get(key)); break; case '\n': bw.write("\\n" + "=" + tm.get(key)); break; case '\r': bw.write("\\r" + "=" + tm.get(key)); break; case ' ': bw.write("空格" + "=" + tm.get(key)); break; default: bw.write(key + "=" + tm.get(key)); break; } bw.newLine(); } // 7,关闭输出流 bw.close(); } }** * 当我们下载一个试用版软件,没有购买正版的时候,每执行一次就会提醒我们还有多少次使用机会用学过的IO流知识,模拟试用版软件, * 试用10次机会,执行一次就提示一次您还有几次机会,如果次数到了提示请购买正版 * @throws IOException * 分析: * 1,创建带缓冲的输入流对象,因为要使用readLine方法,可以保证数据的原样性 * 2,将读到的字符串转换为int数 * 3,对int数进行判断,如果大于0,就将其--写回去,如果不大于0,就提示请购买正版 * 4,在if判断中要将--的结果打印,并将结果通过输出流写到文件上 */ public class Test7 { public static void main(String[] args) throws IOException { // 1,创建带缓冲的输入流对象,因为要使用readLine方法,可以保证数据的原样性 BufferedReader br = new BufferedReader(new FileReader("config.txt")); // 2,将读到的字符串转换为int数 String line = br.readLine(); int times = Integer.parseInt(line); // * 3,对int数进行判断,如果大于0,就将其--写回去,如果不大于0,就提示请购买正版 if (times > 0) { // 4,在if判断中要将--的结果打印,并将结果通过输出流写到文件上 System.out.println("您还有" + times-- + "次机会"); FileWriter fw = new FileWriter("config.txt"); fw.write(times + ""); fw.close(); } else { System.out.println("您的使用次数已到,请购买正版"); } } }

递归

public class Demo8_Digui { /** * @param args * 递归:方法自己调用自己 * 5! * 5 * 4 * 3 * 2 * 1 * * 5 * fun(4)(代表4!) * 4 * fun(3)(代表3!) * 3 * fun(2)(代表2!) * 2 * fun(1)(代表1!) * 递归的弊端:不能调用次数过多,容易导致栈内存溢出 * 递归的好处:不用知道循环次数 * * 构造方法是否可以递归调用? * 构造方法不能使用递归调用 * * 递归调用是否必须有返回值? * 不一定(可以有,也可以没有) */ public static void main(String[] args) { /*int result = 1; for(int i = 1; i <= 5; i++) { result = result * i; } System.out.println(result);*/ System.out.println(fun(6000)); } public static int fun(int num) { if (num == 1) { return 1; } else { return num * fun(num - 1); } } }

练习

import java.io.File; import java.util.Scanner; /** * 需求:从键盘输入接收一个文件夹路径,打印出该文件夹下所有的.java文件名 * * 分析: * 从键盘接收一个文件夹路径 * 1,如果录入的是不存在,给与提示 * 2,如果录入的是文件路径,给与提示 * 3,如果是文件夹路径,直接返回 * * 打印出该文件夹下所有的.java文件名 * 1,获取到该文件夹路径下的所有的文件和文件夹,存储在File数组中 * 2,遍历数组,对每一个文件或文件夹做判断 * 3,如果是文件,并且后缀是.java的,就打印 * 4,如果是文件夹,就递归调用 */ public class Test8 { private static Scanner sc; public static void main(String[] args) { File dir = getDir(); printJava(dir); } /*从键盘接收一个文件夹路径 * 1,如果录入的是不存在,给与提示 * 2,如果录入的是文件路径,给与提示 * 3,如果是文件夹路径,直接返回*/ /* * 获取键盘录入的文件夹路径 * 1,返回值类型File * 2,不需要有参数 */ public static File getDir() { Scanner sc = new Scanner(System.in); System.out.println("请输入一个文件夹名"); while (true) { String line = sc.nextLine(); File dir = new File(line); if (!dir.exists()) { System.out.println("您录入的文件夹不存在,请重新录入"); } else if (dir.isFile()) { System.out.println("您录入的是个文件,请重新录入"); } else return dir; } } /* * 获取文件夹路径下的所.java文件 * 1,返回值类型 void * 2,参数列表File dir */ public static void printJava(File dir) { // 1,获取到该文件夹路径下的所有的文件和文件夹,存储在File数组中 File[] subFiles = dir.listFiles(); // 2,遍历数组,对每一个文件或文件夹做判断 for (File subFile : subFiles) { // 3,如果是文件,并且后缀是.java的,就打印 if (subFile.isFile() && subFile.getName().endsWith(".java")) { System.out.println(subFile); // 4,如果是文件夹,就递归调用 } else if (subFile.isDirectory()) { printJava(subFile); } } } }


    你可能想看:

    扫描二维码推送至手机访问。

    版权声明:本文由皇冠云发布,如需转载请注明出处。

    本文链接:https://www.idchg.com/info/21980.html

    分享给朋友:

    “我的世界Java坐标怎么常驻” 的相关文章

    CN2服务器vsping测评:助力企业轻松搭建高效云服务

    随着云计算的快速发展,企业对云服务的需求日益增长。而CN2服务器作为国内领先的云服务提供商之一,凭借其高效的网络性能和优质的服务,赢得了众多用户的青睐。本文将重点围绕CN2服务器的vsping测评展开,为您解析其核心优势、性能表现以及实际应用中的用户体验。CN2服务器vsping测评:什么是vspi...

    检查自己的IP地址:全面掌握网络安全与故障排查技巧

    检查自己的IP地址的重要性 我常常感受到,了解自己的IP地址是使用互联网时不可或缺的一部分。无论是日常上网还是进行复杂的网络设置,IP地址都扮演着关键角色。所以,搞清楚自己的IP地址,真的非常重要。 那么,什么是IP地址呢?简单来说,IP地址是分配给每台连接到互联网设备的唯一标识符。它就像我们的家庭...

    HostYun:高性价比VPS服务的理想选择

    HostYun,最早被称作主机分享,成立于2008年,专注于提供性价比极高的VPS服务。在众多IDC品牌中,HostYun凭借其低价策略迅速占领了一席之地。作为一个以KVM和XEN虚拟化技术为基础的平台,HostYun不仅满足了用户对低成本服务的需求,也为学习、测试和小型项目的部署提供了理想的选择。...

    全面解析UDP攻击:类型、影响及有效防御策略

    在当今网络环境中,UDP攻击是一个话题无法忽视的安全隐患。它是一种常见的网络攻击形式,通常会给目标服务器带来严重的资源消耗。为了更好地理解这一现象,我们不妨简单回顾一下UDP协议的特性,以及攻击者是如何利用这一协议实施攻击的。 UDP,即用户数据报协议(User Datagram Protocol)...

    甲骨文云免费IPv6服务详解:轻松配置与应用技巧

    甲骨文云,作为一个综合性的云服务提供商,正迅速崛起于众多的云技术平台之中。它不仅拥有强大的数据处理能力,还提供了多种免费的云服务选项,让个人和企业都能以更低的成本探索并使用云计算的强大功能。首先,我对甲骨文云的快速适应能力和多种灵活服务感到印象深刻,尤其是它的免费套餐项目,吸引了不少用户前来试用。...

    Rndc2的线路怎么样?全面评测RackNerd洛杉矶DC02机房

    Rndc2的基本线路信息 说到Rndc2的线路,首先让我跟大家分享一下它的基本信息。这个线路的核心在于RackNerd洛杉矶DC02机房,位置恰好在美国西海岸的洛杉矶。成立于2019年的RackNerd,以其价格优势著称,给我们提供了比较便宜的美国VPS选择,最低年付大约10美元,这对于很多希望节省...