IO流可以分为字节输入流,字节输出流,对应抽象类是InputSteam、OutputStream, 字符输入流,字符输出流,对应抽象类是Reader、Writer
访问文件:FileInputStream、
缓冲流:BufferedInputStream、 对象流 ObjectInputStream
打开大文件,应该避免直接把文件全部读取存到内存中,可以才有分次读取的方式。
BIO ,Blocking I/O, 同步阻塞式IO,也就是传统IO。特点是模式简单使用方便,并发处理能力低。数据的读取写入必须阻塞在一个线程内等待其完成。不适合高并发的系统
NIO: Non-blocking I/O: 同步非阻塞IO, 是传统IO升级。客户端和服务端通过Channel通讯,实现了多路复用。Java1.4引入java.nio包,
有Channel、Buffer、Selector三部分组成。数据可以从Channel读到Buffer中,也可以从Buffer写到Channel中。Buffer本质上是一块可以写入数据,然后可以从中读取数据的内存。Selector允许单线程处理多个 Channel,如果你的应用打开了多个连接(通道),但每个连接的流量都很低,使用Selector就会很方便。要使用Selector,得向Selector注册Channel,然后调用它的select()
方法。
对象的序列化机制就是把内存中的Java对象转化成和平台无关的二进制流,从而允许把这个二进制流持久的保存在磁盘上,或者通过网络把这种二进制流传输到另一个网络节点。当其他程序获取了这种二进制流,就可以通过反序列化机制恢复成原来的Java对象。
serialVersionUID代表序列化的版本,通过定义类的序列化版本,在反序列化时,只要对象中所存的版本和当前类的版本一致,就允许做恢复数据的操作,否则将会抛出InvalidClassException序列化版本不一致的错误。
假如没有指定 serialVersionUID, Java 序列化过程中也会根据 class 文件自动生成一个 serialVersionUID 作为该类序列化版本 ID 号, 而如果类发生改动, 那么序列化机会会重新生成一个 serialVersionUID,对类的敏感性较高,可能会出现意外的InvalidClassException,所以最好显式的定义serialVersionUID
JSON: 目前使用比较频繁的格式化数据工具,简单直观可读性好。有Jackson、gson、fastjson等
可以使用Java原生的序列化机制,但是效率比较低一些,适合小项目;
可以使用其他的一些第三方类库,比如Thrift, 是轻量级RPC服务框架