Java IO详解(四)------字符输入输出流

 File 类的介绍:https://cloud.tencent.com/developer/article/1012532

Java IO 流的分类介绍:https://cloud.tencent.com/developer/article/1012539

Java IO 字节输入输出流:https://cloud.tencent.com/developer/article/1012565

那么这篇博客我们讲的是字节输入输出流:Reader、Writer(下图红色长方形框内),红色椭圆框内是其典型实现(FileReader、FileWriter)

①、为什么要使用字符流?

  因为使用字节流操作汉字或特殊符号语言的时候容易乱码,因为汉字不止一个字节,为了解决这个问题,建议使用字符流。

②、什么情况下使用字符流?

  一般可以用记事本打开的文件,我们可以看到内容不乱码的。就是文本文件,可以使用字符流。而操作二进制文件(比如图片、音频、视频)必须使用字节流

 1、字符输出流:FileWriter

public abstract class Writer
  extends Object
  implements Appendable, Closeable, Flushable

  用于写入字符流的抽象类

  方法摘要:

  下面我们用 字符输出流 Writer  的典型实现 FileWriter 来介绍这个类的用法:

//1、创建源
		File srcFile = new File("io"+File.separator+"a.txt");
		//2、创建字符输出流对象
		Writer out = new FileWriter(srcFile);
		//3、具体的 IO 操作
			/***
			 * void write(int c):向外写出一个字符
			 * void write(char[] buffer):向外写出多个字符 buffer
			 * void write(char[] buffer,int off,int len):把 buffer 数组中从索引 off 开始到 len个长度的数据写出去
			 * void write(String str):向外写出一个字符串
			 */
		//void write(int c):向外写出一个字符
		out.write(65);//将 A 写入 a.txt 文件中
		//void write(char[] buffer):向外写出多个字符 buffer
		out.write("Aa帅锅".toCharArray());//将 Aa帅锅 写入 a.txt 文件中
		//void write(char[] buffer,int off,int len)
		out.write("Aa帅锅".toCharArray(),0,2);//将 Aa 写入a.txt文件中
		//void write(String str):向外写出一个字符串
		out.write("Aa帅锅");//将 Aa帅锅 写入 a.txt 文件中
		
		//4、关闭流资源
		/***
		 * 注意如果这里有一个 缓冲的概念,如果写入文件的数据没有达到缓冲的数组长度,那么数据是不会写入到文件中的
		 * 解决办法:手动刷新缓冲区 flush()
		 * 或者直接调用 close() 方法,这个方法会默认刷新缓冲区
		 */
		out.flush();
		out.close();

 2、字符输入流:Reader

public abstract class Reader
  extends Object
  implements Readable, Closeable

  用于读取字符流的抽象类。

  方法摘要:

  下面我们用 字符输入流 Reader  的典型实现 FileReader 来介绍这个类的用法:

//1、创建源
		File srcFile = new File("io"+File.separator+"a.txt");
		//2、创建字符输出流对象
		Reader in = new FileReader(srcFile);
		//3、具体的 IO 操作
			/***
			 * int read():每次读取一个字符,读到最后返回 -1
			 * int read(char[] buffer):将字符读进字符数组,返回结果为读取的字符数
			 * int read(char[] buffer,int off,int len):将读取的字符存储进字符数组 buffer,返回结果为读取的字符数,从索引 off 开始,长度为 len
			 * 
			 */
		//int read():每次读取一个字符,读到最后返回 -1
		int len = -1;//定义当前读取字符的数量
		while((len = in.read())!=-1){
			//打印 a.txt 文件中所有内容
			System.out.print((char)len); 
		}
		
		//int read(char[] buffer):将字符读进字符数组
		char[] buffer = new char[10]; //每次读取 10 个字符
		while((len=in.read(buffer))!=-1){
			System.out.println(new String(buffer,0,len));
		}
		
		//int read(char[] buffer,int off,int len)
		while((len=in.read(buffer,0,10))!=-1){
			System.out.println(new String(buffer,0,len));
		}
		//4、关闭流资源
		in.close();

3、用字符流完成文件的复制

/**
		 * 将 a.txt 文件 复制到 b.txt 中
		 */
		//1、创建源和目标
		File srcFile = new File("io"+File.separator+"a.txt");
		File descFile = new File("io"+File.separator+"b.txt");
		//2、创建字符输入输出流对象
		Reader in = new FileReader(srcFile);
		Writer out = new FileWriter(descFile);
		//3、读取和写入操作
		char[] buffer = new char[10];//创建一个容量为 10 的字符数组,存储已经读取的数据
		int len = -1;//表示已经读取了多少个字节,如果是 -1,表示已经读取到文件的末尾
		while((len=in.read(buffer))!=-1){
			out.write(buffer, 0, len);
		}
		
		//4、关闭流资源
		out.close();
		in.close();

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏一名合格java开发的自我修养

如何遍历文件夹下上亿文件而不栈溢出

序:一个文件夹下面有很多层的小文件,如何算出这个文件夹下面有多少文件?递归遍历,简单暴力,递归在一般情况确实是比较方便的解决方案,但是当文件夹深度多深,递归的反...

743
来自专栏Java技术分享

泛形

一. 泛型概念的提出(为什么需要泛型)? 首先,我们看下下面这段简短的代码:

17510
来自专栏马洪彪

Java设计模式(五)Prototype原型模式

一、场景描述 创建型模式中,从工厂方法模式,抽象工厂模式,到建造者模式,再到原型模式,我的理解是,创建对象的方式逐步从编码实现转向内存对象处理。 例如,在“仪器...

2667
来自专栏拂晓风起

java 字符串编码转换 字符集/编码的见解 心得 体会(跟之前那个C++编码随笔对应)

1283
来自专栏青枫的专栏

Scanner类的概述及其构造方法

781
来自专栏用户2442861的专栏

JAVA 对象序列化(一)——Serializable

http://www.cnblogs.com/chenfei0801/archive/2013/04/05/3001149.html

513
来自专栏流媒体

Prototype模式简介

用于创建重复的对象,同时又能保证性能。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。这种模式是实现了一个原型接口,该接口用于创建当前对象的克...

581
来自专栏CRPER折腾记

JS不靠谱系列之枚举出时间段和对应的分钟数(新增遍历功能)

今天遇到一个需求,是把选择时间段转为分钟数提交上去的; 所以想手动写个数组一一映射,提交的时候遍历下匹配的值提交.

702
来自专栏编程心路

看完这个,Java IO从此不在难

Java IO 体系看起来类很多,感觉很复杂,但其实是 IO 涉及的因素太多了。在设计 IO 相关的类时,编写者也不是从同一个方面考虑的,所以会给人一种很乱的感...

1085
来自专栏猿人谷

C++容器与算法

容器:某一类型数据的集合。 C++标准顺序容器包括:vector,list,queue 容器初始化 vector<int> t; ...

17710

扫码关注云+社区