Java IO流

文件

定义:
相关记录或放在一起的数据的集合。
确定文件属性:

代表文件的类就是File类。

File类:

**作用:**通过流来读写文件。
**定义:**流是一连串流动的字符,是以先进先出的方式发送信息的通道。
就像一扇门,InputStream是一扇让数据进入当前程序的门;OutputStream是一扇让当前进程产生的数据传送出去的门。

分类:
1)按照流向分类:
输出流:OutputStream、Writer作为基类
输入流:InputStream、Reader作为基类

2)按照处理数据的单元分类:
字节流:字节输入流InputStream基类、字节输出流OutputStream基类。
字符流:字符输入流Reader基类、字符输出流Writer基类。

字节流是8位通用字节流,字符流是16位的unicode字符流。

3)按照功能分类:
节点流:可以直接从数据源或者目的地读写数据。
处理流(包装流):不直接连接到数据源或者目的地,对其他流进行封装。目的是简化操作和提高性能。

节点流和处理流之间的关系:
1)节点流处于io操作的第一线,所有的操作都必须通过它们进行。
2)处理流可以对其他流进行处理,为了提高效率和操作灵活性。

文件的读写

文本文件的读写
用FileInputStream和FileOutputStream字节流读写文本文件。
用BufferedReader和BufferedWriter字符流读写文本文件。

二进制文件的读写:
使用DataInputStream和DataoutputStream读写二进制文件以及基本数据类数据的读写。

对象的读写:
使用ObjectInputStream和ObjectOutputStream读写对象。(序列化和反序列化)



使用字符流读写文本文件

1)读文件:使用Reader抽象类实现



2)写文件:使用Writer抽象类实现


Reader和Writer的编码方式

  • 获得当前开发环境的字符编码方式
  • System.out.println(System.getProperty(“file.encoding”));
  • 字符流的读写需要设置编码方式
  • 涉及到的类:
    读:FileReader(File file)
    写:FileWriter (File file)
    加入缓冲区的读:BufferedReader(Reader fr)
    加入缓冲区的写:BufferderWriter(Writer wr)

Reader与Writer的编码方式



System.in和System.out都在java,lang包下。

操作对象的流

序列化对象:ObjectOutputStream
反序列化对象:ObjectInputStream

序列化:

反序列化:

  1. 类必须实现Serializable接口
  2. 给类加个序列化编号,给类定义一个标记。 新的修改后的类还可以操作曾经序列化的对象
  3. 静态是不能被序列化的,序列化只能对堆中的进行序列化,不能对“方法区”中的进行序列化
  4. 不需要序列化的字段前面加上 transient

操作基本数据的流对象DataStream


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值