处理流:包在别的流上的流,可以对被包的流进行处理或者提供被包的流不具备的方法。
一、缓冲流:套接在相应的节点流之上,带有缓冲区,对读写的数据提供了缓冲的功能,提高读写效率,同时增加一些新的方法。可以减少对硬盘的读写次数,保护硬盘。
     1、四种缓冲流:BufferedReader、BufferedWriter、BufferedInputStream、BufferedOutputStream
     2、常用的构造方法:
          BufferedReader(Reader in);创建默认缓冲区大小的字符输入缓冲流。
          BufferedReader(Reader in, int sz); 创建缓冲区大小为sz的字符输入缓冲流。当sz<=0时,会报IllegalArgumentException异常。
          BufferedWriter(Writer out);创建默认缓冲区大小的字符输出缓冲流。
          BufferedWriter (Writer out , int sz); 创建缓冲区大小为sz的字符输出缓冲流。当sz<=0时,会报IllegalArgumentException异常。
          BufferedInputStream(InputStream in); 创建默认缓冲区大小的字节输入缓冲流。        
            BufferedInputStream(InputStream in,int sz); 创建缓冲区大小为sz的字节输入缓冲流,当sz<=0时,会报IllegalArgumentException异常。
          BufferedOutputStream( Writer out); 创建默认缓冲区大小的字节输出缓冲流。
          BufferedOutputStream( Writer out, int sz ); 创建缓冲区大小为sz的字节输出 缓冲流,当sz<=0时,会报IllegalArgumentException异常。
     3、缓冲输入流继承了父类的mark(int i)和reset()方法,mark方法在i位置做一个标记,再读的时候就从位置100开始往下读,当i<0时,会报IllegalArgumentException异常 ,当出现IO错误时,会报IOException异常;reset()方法是跳回到该输入流最后mark的位置,从这个位置开始接下来的操作,如果输入流没有做过标记或标记不存在,会报IOException异常 。
     4、BufferedReader提供readLine()方法用于读取一行字符串,该方法抛出IOException异常。
     5、BufferedWriter提供newLine()方法用于写入换行。
     6、对于输出的缓冲流BufferedWriter和BufferedOutputStream,写出的数据会先在内存中缓存,使用flush方法将内存中的数据立刻写出。
 
练习小程序1:从标记处开始读写文件中的内容
package test.io.buffered;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException;
public class BufferedReaderTest {
     public static void main(String args[]){
           File f = new File("E:/技术学习/java/test/Socket/test1.txt");
           FileReader fr = null;
           BufferedReader br = null;
           int b = 0;
           try {
                fr = new FileReader(f);
                br = new BufferedReader(fr);
                br.mark(100);
                for(int i=0; i<10 && (b=br.read()) != -1;i++){//从文件中mark的位置开始,读取10个字符并打印在控制台上
                     System.out.print(b+" ");
                }
                System.out.println();
                System.out.println("第一次读取数据完毕");
                br.reset();//重新回到最近标记mark的位置
                //b = br.read();发生读写错误时,报IOException
                for(int i=0; i<10 && (b=br.read()) != -1;i++){//从文件中mark的位置开始,读取10个字符并打印在控制台上,当输入流没有mark标记,或者mark标记错误时,报IOException
                     System.out.print(b+" ");
                }
                System.out.println();
                System.out.println("第二次读取数据完毕");
           } catch (FileNotFoundException e) {//FileReader(File file)构造方法可能会抛出的异常,检查性异常,是IOException的子类
                e.printStackTrace();
                System.out.println("文件没找到");
           } catch(IllegalArgumentException e){//br.mark(int i)当i<0时会抛出的异常,java.lang包的运行时异常
                e.printStackTrace();
                System.out.println("mark标记错误");
           } catch (IOException e){//br.mark(int i)方法可能会抛出的读写异常,检查性异常
                e.printStackTrace();
           }finally{
                try {
                     fr.close();
                     br.close();
                } catch (IOException e) {
                     e.printStackTrace();
                }
           }
     }
}
控制台结果:
65279 22270 20687 22686 24378 20316 20026 22270 20687 39044
第一次读取数据完毕
65279 22270 20687 22686 24378 20316 20026 22270 20687 39044
第二次读取数据完毕
注:关于异常处理,如果try 。。catch语句后面还有其他的语句,即使发生异常但在catch语句中捕获了,try。。catch语句后面的语句还是会执行,知识终止了try块中发生异常之后的语句的执行。如果发生的是没有捕获的非检查性异常,那么控制台会报异常,并且后面的代码都不会执行。
 
练习小程序2:用字符输出流将0-99写入到文件中,再用字符输入流读出来显示在控制台上
package test.io.buffered;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class BufferedRWTest {
     public static void main(String[] args){
           FileReader fr = null;
           BufferedReader br = null;
           FileWriter fw = null;
           BufferedWriter bw = null;
           int bb = 0;
           try {
                fw = new FileWriter("E:/技术学习/java/test/Socket/test3.txt");
                bw = new BufferedWriter(fw);
                fr = new FileReader("E:/技术学习/java/test/Socket/test3.txt");
                br = new BufferedReader(fr);
                for(int i=0; i<100; i++){
                     String s = String.valueOf(i);
                     bw.write(s);
                }
                bw.flush();
                while((bb = br.read()) != -1){
                     System.out.print((char)bb+" ");
                }
           } catch (IOException e) {
                e.printStackTrace();
           }finally{
                try {
                     fr.close();
                     br.close();
                     fw.close();
                     bw.close();
                } catch (IOException e) {
                     e.printStackTrace();
                }
           }
     }
}
控制台结果:

0 1 2 3 4 5 6 7 8 9 1 0 1 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 2 0 2 1 2 2 2 3 2 4 2 5 2 6 2 7 2 8 2 9 3 0 3 1 3 2 3 3 3 4 3 5 3 6 3 7 3 8 3 9 4 0 4 1 4 2 4 3 4 4 4 5 4 6 4 7 4 8 4 9 5 0 5 1 5 2 5 3 5 4 5 5 5 6 5 7 5 8 5 9 6 0 6 1 6 2 6 3 6 4 6 5 6 6 6 7 6 8 6 9 7 0 7 1 7 2 7 3 7 4 7 5 7 6 7 7 7 8 7 9 8 0 8 1 8 2 8 3 8 4 8 5 8 6 8 7 8 8 8 9 9 0 9 1 9 2 9 3 9 4 9 5 9 6 9 7 9 8 9 9
 
注意:如果向文件中写内容的时候,用的是bw.write(i);,最后读出的内容是正确的,但是文件test3里是乱码,这是因为:
 

FileWriter从类OutputStreamWriter继承的

1、public void write(int c)

           throws IOException       写入单个字符。

c - 指定要写入字符的ASCII。

这里data数组中的整数是作为字符的ASCII,最终显示的是ASCII值为这些的字符,并不是这些数字本身。要显示这些数字本身,可改为:

fos.write(String.valueOf(data[i]));

注意valueOf()方法的大小写。
如果改成bw.write(i),读出时直接读出整数,则test3.txt文件里的内容是乱码,但控制台的结果为:
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
这是因为读出的是txt文件中字符对应的ASCII码。
 
练习小程序3:用字符输出流将写入100个随机数,再用字符输入流读出来显示在控制台上
package test.io.buffered;
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class BufferedRWTest2 {
     public static void main(String[] args){
           FileReader fr = null;
           BufferedReader br = null;
           FileWriter fw = null;
           BufferedWriter bw = null;
           String brs = null;
           try {
                fw = new FileWriter("E:/技术学习/java/test/Socket/test3.txt");
                bw = new BufferedWriter(fw);
                fr = new FileReader("E:/技术学习/java/test/Socket/test3.txt");
                br = new BufferedReader(fr);
                for(int i=0; i<100; i++){
                     String s = String.valueOf(Math.random());
                     bw.write(s);
                     bw.newLine();//写换行
                }
                bw.flush();
                while((brs = br.readLine()) != null){//一行一行地读取数据
                     System.out.println(brs);
                }
           } catch (IOException e) {
                e.printStackTrace();
           }finally{
                try {
                     fr.close();
                     br.close();
                     fw.close();
                     bw.close();
                } catch (IOException e) {
                     e.printStackTrace();
                }
           }
     }
}
控制台结果:

0.6399078291426284
0.5310687702453183
0.07905828584716501
0.9775791681606492
0.9972963523338569
0.6270002181751103
0.32321014986324836
0.11986615499082587
0.6262995365951884
0.6471374123463838
0.18990862494691974
0.4222818554711282
0.38697078015460185
0.36813804843744213
0.4187311475705796
0.8574595913364991
0.5820077024425427
0.22710072783387325
0.25959286952389915
0.18084247442308043
0.6062797615480818
0.25038195025388255
0.20803902668018115
0.42164806730949234
0.8055207170483544
0.40612434707860023
0.9298802823497532
0.9741340249616823
0.13662312072846572
0.22708341675840704
0.532551039593457
0.7046003018948346
0.7659185489756097
0.1645996012699773
0.337639616451081
0.6819464480745878
0.4420214977822119
0.15506860771931874
0.9623602909094771
0.2382356012405551
0.3362606335315719
0.3070224055669991
0.8273073150411092
0.07059925358864483
0.056416805839150874
0.4499394034542309
0.1736512770799683
0.006949859283200466
0.7084314074683844
0.5251618294701433
0.2950084178495689
0.8753513196437038
0.20594558736495272
0.44480467390469114
0.9675341011496371
0.6405295602033448
0.5089744213852115
0.0962994261241209
0.9963616576709458
0.6008893611678685
0.11071690333808759
0.6282230301581236
0.38732823731703636
0.9755349987760249
0.8854467995681203
0.01732058970179995
0.8999998323452159
0.6531763150840912
0.3606257669509091
0.18713813571495808
0.6413273645264072
0.2234340278132939
0.5828245243281741
0.6254392584483947
0.9188368391336925
0.6659407297905311
0.009733584234613901
0.5305880161519759
0.7880762406832532
0.23376755621440615
0.27949064985006944
0.0063371356786929844
0.6011123896488713
0.13508856310676753
0.283746575994804
0.719969586040774
0.3911913080674342
0.5906280248644384
0.7023371386786247
0.74049864944887
0.11324600836773635
0.7243187220974489
0.04512387442540411
0.9816394666939254
0.6007556960627297
0.5307320317427977
0.2905115094340368
0.7885231882741083
0.5965311168205768
0.8552232199742466

Java IO学习笔记(二)缓冲流的更多相关文章

  1. Java IO学习笔记二

    Java IO学习笔记二 流的概念 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入输 ...

  2. Java IO学习笔记二:DirectByteBuffer与HeapByteBuffer

    作者:Grey 原文地址:Java IO学习笔记二:DirectByteBuffer与HeapByteBuffer ByteBuffer.allocate()与ByteBuffer.allocateD ...

  3. Java IO学习笔记:概念与原理

    Java IO学习笔记:概念与原理   一.概念   Java中对文件的操作是以流的方式进行的.流是Java内存中的一组有序数据序列.Java将数据从源(文件.内存.键盘.网络)读入到内存 中,形成了 ...

  4. Java IO学习笔记三

    Java IO学习笔记三 在整个IO包中,实际上就是分为字节流和字符流,但是除了这两个流之外,还存在了一组字节流-字符流的转换类. OutputStreamWriter:是Writer的子类,将输出的 ...

  5. Java IO学习笔记总结

    Java IO学习笔记总结 前言 前面的八篇文章详细的讲述了Java IO的操作方法,文章列表如下 基本的文件操作 字符流和字节流的操作 InputStreamReader和OutputStreamW ...

  6. Java IO学习笔记一

    Java IO学习笔记一 File File是文件和目录路径名的抽象表示形式,总的来说就是java创建删除文件目录的一个类库,但是作用不仅仅于此,详细见官方文档 构造函数 File(File pare ...

  7. Java IO学习笔记一:为什么带Buffer的比不带Buffer的快

    作者:Grey 原文地址:Java IO学习笔记一:为什么带Buffer的比不带Buffer的快 Java中为什么BufferedReader,BufferedWriter要比FileReader 和 ...

  8. Java IO学习笔记三:MMAP与RandomAccessFile

    作者:Grey 原文地址:Java IO学习笔记三:MMAP与RandomAccessFile 关于RandomAccessFile 相较于前面提到的BufferedReader/Writer和Fil ...

  9. Java IO学习笔记四:Socket基础

    作者:Grey 原文地址:Java IO学习笔记四:Socket基础 准备两个Linux实例(安装好jdk1.8),我准备的两个实例的ip地址分别为: io1实例:192.168.205.138 io ...

  10. Java IO学习笔记六:NIO到多路复用

    作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...

随机推荐

  1. 9、JcomboBox下拉框事件监听

    9.JcomboBox下拉框事件监听 JComboBox()的事件监听类ItemListener.其范例代码如下: import java.awt.*; import java.awt.event.* ...

  2. Ajax01 什么是ajax、获取ajax对象、ajax对象的属性和方法

    1 什么是ajax ajax是一种用来改善用户体验的技术,其本质是利用浏览器提供的一个对象(XMLHttpRequest,也可称之为ajax对象) 向服务器发送异步请求;服务器返回部分数据(不是一个完 ...

  3. JavaScript 闭包究竟是什么

    用JavaScript一年多了,闭包总是让人二丈和尚摸不着头脑.陆陆续续接触了一些闭包的知识,也犯过几次因为不理解闭包导致的错误,一年多了 资料也看了一些,但还是不是非常明白,最近偶然看了一下 jQu ...

  4. javaWeb学习总结(11)- 监听器(Listener)学习(2)

    一.监听域对象中属性的变更的监听器 域对象中属性的变更的事件监听器就是用来监听 ServletContext, HttpSession, HttpServletRequest 这三个对象中的属性变更信 ...

  5. Ajax02 json

    1 什么是json JavaScript Object Notation(JavaScript 对象表示法) 是一种轻量级的数据交换格式. 注: 数据交换:将数据先转换成一种与平台无关的数据 格式(比 ...

  6. asp.net core利用DI实现自定义用户系统,脱离ControllerBase.User

    前言 很多时候其实我们并不需要asp.net core自带的那么复杂的用户系统,基于角色,各种概念,还得用EF Core,而且在web应用中都是把信息存储到cookie中进行通讯(我不喜欢放cooki ...

  7. SpringMVC实现账号只能在一处登陆

    一.问题引导 在Web开发中,实现一个账号只能在一处登陆有两种形式:1.当某个账号在某处登陆后,如果再在其他处登陆,将前一个账号挤掉:2.当某个账号登陆后,此账号在其他设备登陆提示已经登陆,无法登陆. ...

  8. Building [Security] Dashboards w/R & Shiny + shinydashboard(转)

    Jay & I cover dashboards in Chapter 10 of Data-Driven Security (the book) but have barely mentio ...

  9. Virtualbox让kali虚拟机共享主机的无线网络连接

    今天在测试虚拟机下安装kali系统时,遇到一个问题,默认安装完kali系统后,虚拟机不能上网.虚拟机网络配置使用的是默认的网络地址转换(NAT)选项. 网上查了很多,都说使用NAT模式时虚拟机不用做任 ...

  10. markdown 基础语法

    markdown 基础 你好,我是markdown文档 介绍 Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式. 说的简单一点,mar ...