BufferedReader缓冲区处理IO

22 篇文章 0 订阅

BufferedReader类


BufferedReader类用于从缓冲区中读取数据,所有的字节数据都将保存在缓冲区中,BufferedReader类是Reader类的实例,只能接收字符输入流的实例化对象,不理解没关系,通过一个案例就能懂~(嘿嘿)

主要方法

在这里插入图片描述
在这里插入图片描述

案例演示

通过BufferedReader类实例完成无限制地接收键盘输入中文数据并将所有数据打印输出。

package chapter_twelve;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.InputStreamReader;

public class BufferedReaderDemo01 {
    public static void main(String[] args) throws Exception{
        BufferedReader bufferedReader =                     //声明BufferedReader类对象,此对象为Reader类子类
                new BufferedReader(new InputStreamReader(System.in));       //实例化BufferedReader类,参数为字符输入流实例

        System.out.println("请输入要读入的内容:");
        String string = bufferedReader.readLine();          //接收从键盘中读取的数据
        System.out.println("您输入的内容为:");
        System.out.println(string);                     //将用户输入的数据打印出来


    }
}
运行结果
请输入要读入的内容:
Hello,小高同学,别来无恙啊~
您输入的内容为:
Hello,小高同学,别来无恙啊~
总结

使用BufferedReader类通过readLine()方法可以一次性接收用户输入的全部数据或全部读取文件中的内容,也能很好地避免了中文数据拆分输入导致地乱码问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
io流简介 File类 createNewFile() File.pathSwparator 与系统有关的路径分隔符,它被表示为一个字符串 windows为 分号";" File.pathSwparatorChar 与系统有关的路径分割符,它被表示为一个字符 File.separator 与系统有关的 默认名称分隔符 ,它被表示为一个字符串 windows为 斜杠"\" File.separatorChar 与系统有关的 默认名称分隔符 ,它被表示为一个字符 获取目录和文件 File.list() 返回String[] File.listFile() 返回File[] 字节流 FileInputStream("文件路径") FileOutputStream(File file) 逐个读取 存入字节read() write() close() 字符流 FileReader("文件路径") FileWriter("文件路径") 逐个读取 存入字符read() 无缓冲的输入、输出流每一次读写都肯引发磁盘的读写操作,占用大量资源 缓冲流(装饰器模式) 缓冲流是一种装饰器类 可实现按规定字符数、按行等方式的高效读写 缓冲区的大写可指定 也可使用默认大小 FileInputStream fis = new FileInputStream("Car.java"); 装饰器类 in = new 装饰器类(fis); BufferedReader in = new BufferedReader(new FileReader("Car.java")); BufferedWriter out = new BufferedWriter(new FileReader("Car2.java")); 利用缓冲流读取的时候是逐行读取 存入字符串 in.readLine() out.write("") out.newLine()写入分行符 需要即时写入的时候 调用 flush()方法,手动刷新缓冲流 注意 关闭流的时候也会自动刷新缓冲流中的数据 字节流转换为字符流 InputStreamReader(System.in) 适配器模式的使用 其意图是将一个类的接口转换成客户希望的另外一个接口 数据流 简单来说就是容许字节流直接操作基本数据类型和字符串 DataInputStream out = new DataInputStream(new BufferedInputStream(new FileInputStream("数据存储文件路径"))) DataOutputStream out = new DataOutputStream(new BufferedOutputStream(new FileOutputStream("数据存储文件路径")))
在Python中,缓冲区是指用于临时存储数据的内存区域,通常用于提高I/O操作的效率。Python中的文件对象默认是带有缓冲区的,读写文件时,数据会先被读入或写入缓冲区,然后再一次性地写入或读出文件。这种方式可以减少I/O操作的次数,提高程序的性能。 Python中的缓冲区分为全缓冲、行缓冲和无缓冲三种方式: - 全缓冲:当缓冲区满时才进行I/O操作,例如使用`open()`函数打开文件时,设置`buffering`参数为大于1的整数,则会使用全缓冲方式。 - 行缓冲:当输入输出遇到换行符时才进行I/O操作,例如在终端输入时,就是使用行缓冲方式。 - 无缓冲:每次读写都进行I/O操作,例如使用`open()`函数打开文件时,设置`buffering`参数为0,则会使用无缓冲方式。 在Python中,可以使用`sys.stdout.flush()`强制刷新缓冲区,将缓冲区中的数据写入到文件中。另外,可以使用`io`模块提供的`BufferedWriter`、`BufferedReader`、`BufferedRandom`等类,来创建带缓冲区的文件对象,从而实现更高效的I/O操作。例如: ```python import io # 创建带缓冲区的输出文件对象 with io.BufferedWriter(open('output.txt', 'wb')) as f: f.write(b'Hello, world!') # 创建带缓冲区的输入文件对象 with io.BufferedReader(open('input.txt', 'rb')) as f: data = f.read() ``` 以上代码中,`BufferedWriter`和`BufferedReader`类的构造函数都有一个可选参数`buffer_size`,可以用来设置缓冲区的大小。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Gaolw1102

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值