文件字符流读写:FileWriter、FileReader
文件字节流读写:FileInputStream、FileOutputStream
//字符流写文件 File file = new File("D:\1.txt"); if(!file.exists()){ file.createNewFile(); } BufferedWriter bw = new BufferedWriter(new FileWriter(file)); for(int i=0;i<10;i++){ bw.write("i miss you "); } bw.close(); //字符流读文件 File file = new File("D:\1.txt"); if(!file.exists()){ System.out.println("文件不存在"); } FileReader fileReader = new FileReader(file);//绑定字符流与文件 对流进行操作 char []buffer = new char[5]; int counts = fileReader.read(buffer); StringBuffer sb = new StringBuffer(); while(counts!=-1){ sb.append(buffer); counts = fileReader.read(buffer); } System.out.println(sb.toString()); //字节流写文件 File file = new File("D:\1.txt"); FileOutputStream fos = new FileOutputStream(file); String content = "hello world"; fos.write(content.getBytes()); fos.close(); //字节流读文件 File file = new File("D:\1.txt"); FileInputStream fis = new FileInputStream(file); byte[] bytes = new byte[5]; int counts = fis.read(bytes); StringBuffer sb = new StringBuffer(); while(counts!=-1){ sb.append(new String(bytes)); counts = fis.read(bytes); } fis.close(); System.out.println(sb.toString()); //如果读取出来的内容有问题,因为汉字占两个字节,而字符串占一个
流分类:
1.Java的字节流
InputStream是所有字节输入流的祖先,而OutputStream是所有字节输出流的祖先。
2.Java的字符流
Reader是所有读取字符串输入流的祖先,而writer是所有输出字符串的祖先。
InputStream,OutputStream,Reader,writer都是抽象类。所以不能直接new
字符流与字节流直接的转化通过 InputStreamReader,OutputStreamWriter来关联
字符流与字节流区别:
字符流处理的单元为2个字节的Unicode字符,分别操作字符、字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组。所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,所以它对多国语言支持性比较好!如果是音频文件、图片、歌曲,就用字节流好点,如果是关系到中文(文本)的,用字符流好点
所有文件的储存是都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以形成字节序列。
字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串; 2. 字节流提供了处理任何类型的IO操作的功能,但它不能直接处理Unicode字符,而字符流就可以。
字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联 在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的 。