--- stream 数据流 java ---

文件内容的读写 数据流

可以讲数据想象成一个流淌着数据的河流,一条讲cpu和文件数据联系起来的河流,对于数据的读取的类是InputStream,写入是OutPutStream,简单的判断就是你坐在cpu上,数据向你流过来,那么就是读取inputStream,数据从cpu出去,离你越来越远就是写入,OutputStream

数据的读取

InputStream 字节流

以字节为单位来处理数据

InputStream是一个抽象类,使用时需要一个具体的实现类,对于inputStream实现类有很多可以认为每一种输入的对象都有一个单独的实现类

这里对文件进行读取操作,那么就是FileInputStream

|------------------------------------------|-------------------------------------------------------------------------|
| read(byte[] bytes) int | 将数据读取到字节数组中,返回的是成功读取到的数据的个数,读取时数据尽量的多读取到数组中,最多读取bytes.lengh的的长度 -1代表读完了 |
| read() int | 读取一个字节并返回 |
| read(byte[] bytes,int off,int len) int | 从off位置开始,最多读取len-off个数据到数组中 |
| close() void | 关闭字节流防止资源的浪费 |

字符流 FileReader

每次读取一个字符,能够处理字符数据,他可以自动处理字符的编码,按照指定的编码一次读取多个字节来对应一个字符

方法和使用和字节流的一样

数据的写入

字节流 OutputStream

|------------------------|------------------------------------------------------------------------|
| write(int b) void | 将数据写入到指定的对象中去 |
| write(byte[] b) void | 将数组中的全部写入到数组中去 |
| flush() void | 因为为了减少io的次数,那么就会先将数据写入到缓冲区中,这是是没有真正写入到对象中,那么需要使用flush清空缓冲区,将数据强制写入到对象中 |

字符流 FileWriter 和 OutputStream的具体操作相同

包装io类

对于InputStream 和OutputStream的直接使用还是挺麻烦的,这是就可以是用Scanner来读取数据

这是对于数据的操作就是我们所熟悉的scanner对应的方法了

OutPutStream 使用 PrintWriter

PrintWriter 中的方法的是print、printf、println都是我们熟悉的方法

对于方法的使用

可以理解为将数据打印到对象中,也就是写入到了对象中

还有种自动关闭资源的写法

这样在try退出时程序自动关闭资源,这样就确保资源会忘记关闭了

相关推荐
咖啡教室2 小时前
java日常开发笔记和开发问题记录
java
咖啡教室2 小时前
java练习项目记录笔记
java
鱼樱前端3 小时前
maven的基础安装和使用--mac/window版本
java·后端
RainbowSea3 小时前
6. RabbitMQ 死信队列的详细操作编写
java·消息队列·rabbitmq
RainbowSea3 小时前
5. RabbitMQ 消息队列中 Exchanges(交换机) 的详细说明
java·消息队列·rabbitmq
我不会编程5555 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
李少兄5 小时前
Unirest:优雅的Java HTTP客户端库
java·开发语言·http
此木|西贝5 小时前
【设计模式】原型模式
java·设计模式·原型模式
可乐加.糖5 小时前
一篇关于Netty相关的梳理总结
java·后端·网络协议·netty·信息与通信
无名之逆5 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust