IO相关

java操作IO

java操作IO的类 大抵可以用两个维度来分类。

操作类型

  1. 字节操作的  InputStream 和OutputStream
  2. 字符操作的:Writer 和Reader
操作的对象的类型
  1. 磁盘的:File
  2. 网络的:Socket
IO相关_第1张图片
IO相关_第2张图片

IO相关_第3张图片

IO相关_第4张图片

基本都在IO的里面了,而Socket实际上主要还是使用流来做处理。

这里面需要注意的是一个叫StreamDecoder的东西

IO相关_第5张图片

这其实就是InputStream和Reader的最大区别。

IO相关_第6张图片

同理 StreamEncoder


磁盘I/O工作机制

访问文件的几种方式

  1. 标准访问文件的方式 物理磁盘--内核空间--用户空间
  2. 直接I/O    物理磁盘--用户空间   多用于数据库
  3. 内存映射,  物理磁盘--(用户空间/内核空间) 用户空间和内核空间建立共享关系

  1. 同步访问文件方式 数据安全比较高才会使用
  2. 异步访问文件方式  正常情况都会这么干,能提高应用程序的效率,但不会改变访问文件的效率

java序列化

 其实就是根据一定的规则,将字符串变成一长串的byte数组。比较有意思的一点是这样
  1. 父类集成Serializable接口,所有子类都可以被序列化
  2. 子类实现了Serializable接口,父类没有,则父类中的属性不能序列化,子类中的属性能正确序列化。
  3. 对象A有个属性是对象B,则对象B也必须实现Serializable 否则报错
  4. 反序列化的对象如果有删除或者修改。不会报错,但是会丢失修改的属性数据。
  5. 反序列化,如果serialVersionUID被修改,则反序列化时会失败。
如果是JAVA之间的通信,我们用Serializable即可,但是其他语种是不认识的。所以尽量还是使用JSON或者XML这种通用的格式来序列化。

网络IO
tcp状态转化
IO相关_第7张图片
以及状态机
IO相关_第8张图片



你可能感兴趣的:(java,Web读书笔记)