Java怎么实现带缓冲的输入输出流
java
缓冲是 I/O 的一种性能优化。缓冲流为 I/O 流增加了内存缓冲区。
BufferedInputStream类 与 BufferedOutputStream类
BufferedInputStream类 可以对所有InputStream的子类进行缓冲区的包装,以达到性能的优化。
BufferedOutputStream类 中的 flush()方法 被用来把缓冲区的字节写入到文件中,并清空缓存。
BufferedInputStream类的构造方法:
构造方法 | 介绍 |
---|---|
BufferedInputStream(FileInputStream fileInputStream); | 创建一个带有32个字节的缓冲输入流。 |
BufferedInputStream(FileInputStream fileInputStream , int size); | 按指定的大小来创建缓冲输入流。 |
BufferedOutputStream类的构造方法:
构造方法 | 介绍 |
---|---|
BufferedOutputStream(FileOutputStream fileOutputStream); | 创建一个带有32个字节的缓冲输出流。 |
BufferedOutputStream(FileOutputStream fileOutputStream , int size); | 按指定的大小来创建缓冲输出流。 |
BufferedInputStream类 与 BufferedOutputStream类 实例:
import java.io.*; public class Demo4 { public static void main(String[] args) { /** * 缓冲字节输入流(BufferedInputStream) * 特点:提高效率 */ File file = new File("C:\\JAVA_API_1.7中文.chm"); BufferedInputStream bufferedInputStream = null;//创建缓冲字节流 FileInputStream fileInputStream = null; long stare = System.currentTimeMillis();//获得当前流开始时的毫秒值 try { fileInputStream=new FileInputStream(file); bufferedInputStream = new BufferedInputStream(fileInputStream);//将文件字节流包装成缓冲字节流 byte by[] = new byte[1024];//缓冲区字节数组(这个缓冲区与Buffered不同) while ((bufferedInputStream.read(by))!=-1){//使用缓冲字节流读取数据 } long end = System.currentTimeMillis();//获得当前流结束时的毫秒值 System.out.println("运行经历的毫秒数:"+(end - stare)); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (fileInputStream!=null){ try { fileInputStream.close(); } catch (IOException e) { e.printStackTrace(); } } if (bufferedInputStream!=null){ try { bufferedInputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } /** * 缓冲字节输出流(BufferedOutputStream) * 特点:提高效率 */ File file1 = new File("C:\\Word.txt"); BufferedOutputStream bufferedOutputStream = null;//创建缓冲字节输出流 FileOutputStream fileOutputStream = null; try { fileOutputStream=new FileOutputStream(file1); bufferedOutputStream=new BufferedOutputStream(fileOutputStream);//将文件输出流包装到缓冲字节输出流 String str = "深山踏红叶,耳畔闻鹭鸣。"; byte by[] = str.getBytes(); bufferedOutputStream.write(by); //<*> 使用缓冲字节输出流时,要多进行刷新操作,避免等待,有数据时就将数据写入文件当中 <*> bufferedOutputStream.flush();//刷新(强制将缓冲区数据写入文件中,即使缓冲区没有写满) } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (fileOutputStream!=null){ try { fileOutputStream.close(); } catch (IOException e) { e.printStackTrace(); } } if (bufferedOutputStream!=null){ try { bufferedOutputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } } }
登录后复制
BufferedReader类 与 BufferedWriter类
BufferedReader类 与 BufferedWriter类 分别继承了 Reader类 与 Writer类,这两个类同样具有内部缓冲机制,并以行为单位输入/输出。
BufferedReader类常用方法:
BufferedWriter类常用方法:
BufferedReader类 与 BufferedWriter类 实例:
import java.io.*; public class Demo6 { public static void main(String[] args) { File file = new File("C:\\Word.txt"); /** * 文件缓冲字符输出流(BufferedWriter) */ FileWriter fileWriter = null;//创建文件字符输出流 BufferedWriter bufferedWriter = null;//创建文件缓冲字符输出流 try { fileWriter = new FileWriter(file); bufferedWriter = new BufferedWriter(fileWriter);//将文件字符输出流包装成文件缓冲字符输出流 String str1 = "神里"; String str2 = "绫华"; bufferedWriter.write(str1);//第一行数据 bufferedWriter.newLine();//创建一个新行 bufferedWriter.write(str2);//第二行数据 } catch (IOException e) { e.printStackTrace(); }finally {//<*> 注意:流的关闭顺序,先创建的后关闭。 <*> if (bufferedWriter!=null){ try { bufferedWriter.close(); } catch (IOException e) { e.printStackTrace(); } } if (fileWriter!=null){ try { fileWriter.close(); } catch (IOException e) { e.printStackTrace(); } } } /** * 文件缓冲字符输入流(BufferedReader) */ FileReader fileReader = null; BufferedReader bufferedReader = null; try { fileReader = new FileReader(file); bufferedReader = new BufferedReader(fileReader);//将文件字符输入流包装成文件缓冲字符输入流 String tmp = null;//临时变量 int i = 1;//计数器 while ((tmp = bufferedReader.readLine())!=null){//循环读取文件中的内容 System.out.println("第"+i+"行:"+tmp); i++; } } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (bufferedReader!=null){ try { bufferedReader.close(); } catch (IOException e) { e.printStackTrace(); } } if (fileReader!=null){ try { fileReader.close(); } catch (IOException e) { e.printStackTrace(); } } } } }
登录后复制
以上是Java怎么实现带缓冲的输入输出流的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
刺客信条阴影:贝壳谜语解决方案
2 周前
By DDD
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前
By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处
