1.序列化和反序列化是什么?
序列化
序列化就是把对象转换为字节流的过程
反序列化
反序列化就是把字节流重新转换为对象的过程,即从存储中获取数据并且重新创建对象
其他
java中序列化的关键类和接口:ObjectOutputStream用于序列化,
ObjectInputStream用于反序列化,
类必须实现Serializable接口才可以被序列化
transient关键字:在序列化的过程中,有些敏感字段等不需要被序列化的字段,
用transient关键字标记后,就不会被序列化。
serialVersionUID:用于在反序列化时验证版本的统一;如果没有手动的设
置serialVersionUID,在序列化时,会根据类的定义自动设置一个UID,如果序列化之后,
类的定义发生了改变,比如增加了一个字段,则会反序列化失败;简而言之,就是用来
验证。
java的序列化不包含静态变量。
2.什么是java中的不可变类?
不可变类指的是在创建之后,其状态(对象的字段)无法被修改的类。一旦被创建,它的所有的状态都不可以再被修改。
关键特征:
1.类被final修饰,不可以被子类继承
2.所有的字段都被final修饰,并且都是private私有的
3.没有提供修改字段的方法,例如setter等
4.如果不可变类里包含了可变类的引用,确保这些类在外部不可以被修改;例如getter
方法返回一个新的对象来保护可变对象。
java中常见的不可变类:String、Integer、LocalDate等
以String类为例:String类本质是一个char数组(jdk1.8之前,之后是byte数组),并且类被final修饰,char数组也被final修饰,而且还是private私有的,并且没有提供setter方法,因此外界就无法获取到char数组而无法修改;也存在如replace等修改的方法,但是返回的是一个新的对象来作为结果。
总而言之就是:私有化变量,不要暴露setter方法,即使有修改的方法,返回的也是一个新的对象。