字节流和字符流的区别

Java 字节流与字符流的区别

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

下面以两个写文件的操作为主进行比较,但是在操作时字节流和字符流的操作完成之后都不关闭输出流。

字节流:

public static void main(String[] args) throws IOException {// 异常抛出,  不处理
        // 第1步:使用File类找到一个文件 
        //File.separator通用的文件分隔符
        File f = new File("d:" + File.separator + "test.txt"); // 声明File  对象
        // 第2步:通过子类实例化父类对象
        OutputStream out = null;
        // 准备好一个输出的对象
        out = new FileOutputStream(f);
        // 通过对象多态性进行实例化
        // 第3步:进行写操作
        String str = "Hello Sulliven!!!";
        // 准备一个字符串
        byte b[] = str.getBytes();
        // 字符串转byte数组
        out.write(b);
        // 将内容输出
        // 第4步:关闭输出流
        // out.close();
        // 此时没有关闭
    }

以上代码的输出结果是 Hello Sulliven!!! 虽然没有关闭流但是,由于字节流直接操作的是文件,所以文件里是会写进去东西的。

字符流

public static void main(String[] args) throws IOException {// 异常抛出,  不处理
        // 异常抛出,  不处理    
        // 第1步:使用File类找到一个文件    
        File f = new File("d:" + File.separator + "test.txt");// 声明File 对象    
        // 第2步:通过子类实例化父类对象    
        Writer out = null;
        // 准备好一个输出的对象    
        out = new FileWriter(f);
        // 通过对象多态性进行实例化    
        // 第3步:进行写操作    
        String str = "Hello Sulliven!!!";
        // 准备一个字符串    
        out.write(str);
        // 将内容输出    
        // 第4步:关闭输出流    
        // out.close();      
        //out.flush();                       
        // 强制性清空缓冲区中的内容              
        // 此时没有关闭    
    }

程序运行后会发现文件中没有任何内容,这是因为字符流操作时使用了缓冲区,而 在关闭字符流时会强制性地将缓冲区中的内容进行输出,但是如果程序没有关闭,则缓冲区中的内容是无法输出的,所以得出结论:字符流使用了缓冲区,而字节流没有使用缓冲区。

在字符流的操作中,所有的字符都是在内存中形成的,在输出前会将所有的内容暂时保存在内存之中,所以使用了缓冲区暂存数据。

如果想在不关闭时也可以将字符流的内容全部输出,则可以使用Writer类中的flush()方法完成。将第二段代码的out.flush();方法打开,则在运行之后你是可以看到正确的写出的。

但是对于图片等二进制存储的文件,传输的过程要使用字节流,因为若是你使用字符流,程序会吧文件以一个字符的大小为基本单位去获取二进制文件,这样有时候会造成,二进制文件无法正常的显示。

字节流与字符流主要的区别是他们的的处理方式

流分类: 
1.Java的字节流 
InputStream是所有字节输入流的祖先,而OutputStream是所有字节输出流的祖先。 
2.Java的字符流 
Reader是所有读取字符串输入流的祖先,而writer是所有输出字符串的祖先。 
InputStream,OutputStream,Reader,writer都是抽象类。所以不能直接new 

字节流是最基本的,所有的InputStream和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 
但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 
这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联 
在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的

在从字节流转化为字符流时,实际上就是byte[]转化为String时, 
public String(byte bytes[], String charsetName) 
有一个关键的参数字符集编码,通常我们都省略了,那系统就用操作系统的lang

而在字符流转化为字节流时,实际上是String转化为byte[]时, 
byte[] String.getBytes(String charsetName) 
也是一样的道理

至于java.io中还出现了许多其他的流,按主要是为了提高性能和使用方便, 
如BufferedInputStream,PipedInputStream等

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值