java序列化与反序列化的作用
序列化定义:把对象转化为字节序列的过程称为对象的序列化。
反序列化定义:把字节序列恢复成对象的过程称为对象的反序列化。
序列化、反序列化实现方式:标记这个对象可以被持久化,即可以保存在本地文件.txt或者数据库中(用流的方式)。
具体实现方式:1、对象实现Serilizable接口即可。默认方式控制序列化行为。
2、实现Externalizable接口(Externalizable接口继承自Serilizable)。自身方式控制序列化行为。
参考网址:1、http://www.cnblogs.com/xiohao/p/4234184.html
2、http://www.cnblogs.com/xdp-gacl/p/3777987.html
关键字:transient,volatile
transient:标识一个成员变量,应该在序列化中被忽略。
volatile:标识一个成员变量为不稳定的。被读取时,强迫从共享内存中读取该变量的值;被写时,强迫线程将变化值写入共享内存。
从而保证,任何时候,两个线程访问的同一变量,值是一致的。
补充说明:java内存机制
Java使用一个主内存来保存变量当前值,而每个线程则有其独立的工作内存。
线程访问变量的时候会将变量的值拷贝到自己的工作内存中。
这样,当线程对自己工作内存中的变量进行操作之后,就造成了工作内存中的变量拷贝的值与主内存中的变量值不同。
Java语言规范中指出:为了获得最佳速度,允许线程保存共享成员变量的私有拷贝。
而且只当线程进入或者离开同步代码块时才与共享成员变量的原始值对比。
这样当多个线程同时与某个对象交互时,就必须要注意到要让线程及时的得到共享成员变量的变化。