何时使用字节流、何时使用字符流,两者的区别

在程序中全部的数据都是以流的方式进行传输或保存的,程序须要数据的时候要使用输入流读取数据,而当程序须要将一些数据保存起来的时候,就要使用输出流完成。数组


InputStream 和OutputStream,两个是为字节流设计的,主要用来处理字节或二进制对象,
Reader和 Writer.两个是为字符流(一个字符占两个字节)设计的,主要用来处理字符或字符串.
 
字符流处理的单元为2个字节的Unicode字符,操做字符、字符数组或字符串,
字节流处理单元为1个字节,操做字节和字节数组。
因此字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,
因此它对多国语言支持性比较好!
若是是音频文件、图片、歌曲,就用字节流好点,
若是是关系到中文(文本)的,用字符流好点编码


全部文件的储存是都是字节(byte)的储存,在磁盘上保留的并非文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以造成字节序列
字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串;
字节流提供了处理任何类型的IO操做的功能,但它不能直接处理Unicode字符,而字符流就能够
字节流是最基本的,全部的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 
但实际中不少的数据是文本,
又提出了字符流的概念,
它是按虚拟机的encode来处理,也就是要进行字符集的转化 
这两个之间经过 InputStreamReader,OutputStreamWriter来关联,
其实是经过byte[]和String来关联 
在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而形成的 设计


Reader类的read()方法返回类型为int :做为整数读取的字符(占两个字节共16位),范围在 0 到 65535 之间 (0x00-0xffff),若是已到达流的末尾,则返回 -1code


inputStream的read()虽然也返回int,但因为此类是面向字节流的,一个字节占8个位,因此返回 0 到 255 范围内的 int 字节值。若是由于已经到达流末尾而没有可用的字节,则返回值 -1。所以对于不能用0-255来表示的值就得用字符流来读取!好比说汉字.视频

字节流和字符流的主要区别是什么呢?对象

           一.字节流在操做时不会用到缓冲区(内存),是直接对文件自己进行操做的。而字符流在操做时使用了缓冲区,经过缓冲区再操做文件。图片

           二.在硬盘上的全部文件都是以字节形式存在的(图片,声音,视频),而字符值在内存中才会造成。内存

     上面两点能说明什么呢?资源

        针对第一点,开发

       咱们知道,若是一个程序频繁对一个资源进行IO操做,效率会很是低。此时,经过缓冲区,先把须要操做的数据暂时放入内存中,之后直接从内存中读取数据,则能够避免屡次的IO操做,提升效率

       针对第二点,

       真正存储和传输数据时都是以字节为单位的,字符只是存在与内存当中的,因此,字节流适用范围更为宽广

相关文章
相关标签/搜索