如何领会java中字节流和字符流的区别

领会java中字节流和字符流的区别如何

package com.cn;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.InputStreamReader;
import java.io.PrintWriter;


import org.junit.Test;

public class Tests {

	/**
	 * @param args
	 */ 
	@Test
	public void Iotest() throws Exception{
		 String str="中国";
		 //方式一 使用字节流输入,字节流输出,使用了字节流缓冲区
		 FileOutputStream  fos=new FileOutputStream("D://1.txt");
		 fos.write(str.getBytes("UTF-8"));
		 fos.close();
		 
		 FileInputStream  fr=new FileInputStream("D://1.txt");
		 byte[] buf=new byte[1024];
		 int len;
		 String myStr="";
		 while((len=fr.read(buf))!=-1){
			 myStr+=new String(buf, 0, len, "UTF-8");
		 }
		 System.out.println("使用字节流输出的字符为      "+myStr);
		 
		 
		 //方式二  使用字符流输入,字符流输出,使用了字符缓冲区
		    String str2="中国你好";
		   FileWriter  fw=new FileWriter("D://2.txt");
		   fw.write(str2);
		   fw.close();
		   
		   FileReader fr2=new FileReader("D://2.txt");
		   char [] buf2= new char[1024];
		   int len2=fr2.read(buf2);
		   //在这里必须要加上编码字符集,否则会出现乱码
		   String myStr2=new String(buf2, 0, len2);
		   System.out.println("使用字符流输出的字符是    "+myStr2);
		   
		  // 方式三 使用字符流输入,字符流输出,没有使用缓冲区 ,直接读行
		    String str3="中国更好";
		   PrintWriter  pw=new PrintWriter("D://3.txt");
		   pw.write(str3);
		   pw.close();
		   
		   BufferedReader br=new BufferedReader(new InputStreamReader(new  FileInputStream("D://3.txt")));
		   String myStr3=br.readLine();
		   br.close();
		   System.out.println("没有缓冲区      "+myStr3);
	}
}


输出结果;

字节流与和字符流的使用非常相似,两者除了操作代码上的不同之外,是否还有其他的不同呢?

实际上字节流在操作时本身不会用到缓冲区(内存),是文件本身直接操作的,而字符流在操作时使用了缓冲区,通过缓冲区再操作文件,如图。

字节流与字符流

在java.io包中操作文件内容的主要有两大类:字节流、字符流,两类都分为输入和输出操作。在字节流中输出数据主要是使用OutputStream完成,输入使的是InputStream,在字符流中输出主要是使用Writer类完成,输入流主要使用Reader类完成。(这四个都是抽象类)

java中提供了专用于输入输出功能的包Java.io,其中包括:
     InputStream,OutputStream,Reader,Writer
     InputStream 和OutputStream,两个是为字节流设计的,主要用来处理字节或二进制对象,
     Reader和 Writer.两个是为字符流(一个字符占两个字节)设计的,主要用来处理字符或字符串.


字符流处理的单元为2个字节的Unicode字符,分别操作字符、字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组。所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,所以它对多国语言支持性比较好!如果是音频文件、图片、歌曲,就用字节流好点,如果是关系到中文(文本)的,用字符流好点
     所有文件的储存是都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以形成字节序列

      字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串; 2. 字节流提供了处理任何类型的IO操作的功能,但它不能直接处理Unicode字符,而字符流就可以
       字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联 在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的 

发布了146 篇原创文章 · 获赞 1 · 访问量 1775

猜你喜欢

转载自blog.csdn.net/zhupengqq1/article/details/104041209