1. 序列化和反序列化
如果需要持久化 Java 对象(比如将 Java 对象保存在文件中,或者在网络传输 Java 对象),这些场景都需要用到序列化。
-
序列化: 将数据结构或对象转换成二进制字节流的过程
-
反序列化:将在序列化过程中所生成的二进制字节流转换成数据结构或者对象的过程
序列化的主要目的是通过网络传输对象或者说是将对象存储到文件系统、数据库、内存中。
2. transient - 不被序列化
阻止实例中那些用此关键字修饰的的变量序列化;当对象被反序列化时,被 transient
修饰的变量值不会被持久化和恢复。
-
transient
只能修饰变量,不能修饰类和方法。 -
transient
修饰的变量,在反序列化后变量值将会被置成类型的默认值。例如,如果是修饰int
类型,那么反序列后结果就是0
。 -
static
变量因为不属于任何对象(Object),所以无论有没有transient
关键字修饰,均不会被序列化。
3. IO流
3.1 分类
输入和输出。数据输入到计算机内存的过程即输入,反之输出到外部存储(比如数据库,文件,远程主机)的过程即输出。
Stream | Read / Write | |
---|---|---|
Input | 字节输入流 | 字符输入流 |
Output | 字节输出流 | 字符输出流 |
读取数据 | 字节数据 | 字符数据 |
3.2 字节流
TCP
连接传输是基于字节流的,为什么使用字节流,而不是字符流?
字节流主要用于处理二进制数据。字节数据要转成我们能识别的正常字符,需要选择正确的编码方式。
计算机的传输本质都是字节,而一个字符由多个字节组成,
3.3 字符流
字符编码方式不同,有时候一个字符使用的字节数也不一样。比如ASCLL
方式编码的字符,占一个字节;而UTF-8
方式编码的字符,一个英文字符需要一个字节,一个中文需要三个字节。
小纸条:字节和字符