当使用字节流读取文本文件时,可能会有一个小问题。就是遇到中文字符时,可能不会显示完整的字符,那是因为一个中文字符可能占用多个字节存储。所以ava提供一些字符流类,以字符为单位读写数据,专门用于处理文本文件。
1. 字符输入流
java. io. Reader:字符输入流,是字符输入流的最顶层的父类,定义了一些共性的成员方法,是一个抽象类.
共性的成员方法:
- int read() 读取单个字符并返回。
- int read(char[] cbuf)一次读取多个字符,将字符读入数组。
- void close() 关闭该流并释放与之关联的所有资源。
java. io. FiLeReader extends InputStreamReader extends Reader
FileReader:文件字符输入流
作用:把硬盘文件中的数据以字符的方式读取到内存中
构造方法:
- FileReader(String fileName )
- FileReader(File file)
参数:读取文件的数据源
String fileName:文件的路径
File file:一个文件
FileReader构造方法的作用: .
- 创建一个FileReader对象
- 会把FileReader对象指向要读取的文件
字符输入流的使用步骤:
- 创建FileReader对象,构造方法中绑定要读取的数据源
- 使用FileReader对象中的方法read读取文件
- 释放资源
package cn.itcast.day13.demo04;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class Reader01 {
public static void main(String[] args) throws IOException {
//1. 创建FileReader对象,构造方法中绑定要读取的数据
FileReader fr = new FileReader("C:\\Users\\x\\Desktop\\All of D\\test2\\a.txt");
//2. 使用FileReader对象中的方法read读取文件
// int read(char[] cbuf)一次读取多个文件,将字符读入数组
char[] cs = new char[1024];
int len = 0;
while((len = fr.read(cs))!=-1){
/*
String类的构造方法
String(char[] value) 把字符数组转换为字符串
String(char[] value, int offset, int count) 把字符数组的
一部分转换为字符串offset数组的开始索引 count转换的个数
*/
System.out.println(new String(cs,0,len));
}
fr.close();
}
}
2. Write类和FileWrite类
java. io. writer:字符输出流,是所有字符输出流的最顶层的父类,是一个抽象类
共性的成员方法:
- void write(int c)写入单个字符。
- void write(char[] cbuf)写入字符数组。
- abstract void write(char[] cbuf, int off, int len)写入字符数组的某一部分, off数组的开始索引,len写的字符个数。
- void write(String str)写入字符串。
- void write(String str, int off, int len) 写入字符串的某-部分, off字符串的开始索引, Len写的字符个数。
- void flush( )刷新该流的缓冲。
- void close() 关闭此流,但要先刷新它。
java. io.Filewriter extends OutputStreamwriter extends Writer
Filewriter:文件字符输出流
作用:把内存中字符数据写入到文件中
构造方法:
- FileWriter(File file)根据给定的File对象构造一个FileWriter 对象。
- Filewriter(String fileName) 根据给定的文件名构造一个FileWriter 对象。
参数:写入数据的目的地
- String fileName;文件的路径
- File file:是一个文件
构造方法的作用:
- 会创建一个Filewriter对象
- 会根据构造方法中传递的文件/文件的路径,创建文件
- 会把Filewriter对象指向创建好的文件
字符输出流的使用步骤(重点):
- 创建Filewriter对象,构造方法中绑定要写入数据的目的地
- 使用FileWriter中的方法write,把数据写入到内存缓冲区中(字符转换为字节的过程)
- 使用Filewriter中的方法flush,把内存缓冲区中的数据,刷新到文件中
- 释放资源(会先把内存缓冲区中的数据刷新到文件中)
package cn.itcast.day13.demo04;
import java.io.FileWriter;
import java.io.IOException;
public class Writer01 {
public static void main(String[] args) throws IOException {
//1.创建FileWriter对象, 构造方法中绑定要写入数据的目的地
FileWriter fw = new FileWriter("C:\\Users\\x\\Desktop\\All of D\\test2\\b.txt");
//2.使用Filewriter中的方法write,把数据写入到内存缓冲区中(字符转换为字节的过程)
//void write(int C)写入单个字符。
fw.write(97);
fw.close();
}
}
close和flush区别
flush方法和close方法的区别
- flush :刷新缓冲区,流对象可以继续使用。
- close:先刷新缓冲区,然后通知系统释放资源。流对象不可以再被使用了。
3. 字符输出流写数据的其他方法
字符输出流写数据的其他方法
- void write(char[] cbuf)写入字符数组。
- abstract void write(char[]. cbuf, int off, int len)写入字符数组的某一部分, off数组的开始索引, Len写的字符个数。
- void write(String str)写入字符串。
- void write(String str, int off, int len) 写入字符串的某一部分, off字符串的开始索引, len写的字符个数。
package cn.itcast.day13.demo04;
import java.io.FileWriter;
import java.io.IOException;
public class Writer02 {
public static void main(String[] args) throws IOException {
FileWriter fw = new FileWriter("C:\\Users\\x\\Desktop\\All of D\\test2\\b.txt");
char[] cs = {'a','b','c','d'};
fw.write(cs);
fw.write(cs,1,3);
fw.write("周冬雨");
fw.write("刘亦菲小龙女",2,3);
fw.close();
}
}
4. 字符输出流的续写和换行
续写和换行:
续写,追加写:使用两个参数的构造方法
- Filewriter(String fileName, boolean append)
- FileWriter(File file, boolean append)
参数:
- String fileName,File file:写入数据的目的地
- boolean append:续写开关true :不会创建新的文件覆盖源文件,可以续写; false:创建新的文件覆 盖源文件
换行:换行符号
- windows: \r\n
- Linux:/n
- mac:/r
package cn.itcast.day13.demo04;
import java.io.FileWriter;
import java.io.IOException;
public class Writer03 {
public static void main(String[] args) throws IOException {
FileWriter fw = new FileWriter("C:\\Users\\x\\Desktop\\All of D\\test2\\qc.txt",true);
for(int i = 0;i < 10; i++){
fw.write("周冬雨" + i + "\r\n");
}
fw.close();
}
}
5. 使用try_catch_finally处理流中的异常
在jdk1.7之前使用try catch finally 处理流中的异常
格式:
try{
可能会产出异常的代码
}catch(异常类变量变量名){
异常的处理逻辑
}finally{
一定会指定的代码
资源释放.
}
package cn.itcast.day13.demo04;
import java.io.FileWriter;
import java.io.IOException;
public class Writer04 {
public static void main(String[] args) {
//提高变量fw的作用域,让finally可以使用
//变量在定义的时候,可以没有值,但是使用的时候必须有值
FileWriter fw = null;
try {
fw = new FileWriter("C:\\Users\\x\\Desktop\\All of D\\test2\\c.txt");
for(int i = 0; i < 10; i++){
fw.write("周冬雨" + i + "\r\n");
}
} catch (IOException e) {
//异常的处理逻辑
System.out.println(e);
}finally {
//一定会指定的代码
try {
fw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
6. JDk7和JDK9流中异常的处理
JDK7的新特性:在try的后边可以增加一个(),在括号中可以定义流对象那么这个流对象的作用域就在try中有效try中的代码执行完毕,会自动把流对象释放,不用写finally
格式:
try(定义流对象;定义流对象....){
可能会产出异常的代码
}catch(异常类变量变量名){
异常的处理逻辑
}
JDK9新特性
try的前边可以定义流对象
在try后边的( )中可以直接引入流对象的名称(变量名)
在try代码执行完毕之后,流对象也可以释放掉,不用写finally
格式:
A a= new A();
Bb=newB();
try(a,b){
可能会产出异常的代码
}catch(异常类变量变量名){
异常的处理逻辑