java对象是否一定要序列化?为什么?如何反序列化?

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_38500014/article/details/86673862

序列化定义:

首先序列化指的是对象的序列化,流化,是将对象转换为容易传输的格式的过程。例如,可以序列化一个对象,然后使用 HTTP 通过 Internet 在客户端和服务器之间传输该对象。在另一端,反序列化将从该流重新构造对象。也是对象持久化的一种机制

序列化场景:

一般用于读写I/O流文件的时候,或是网络传输,或是做一些持久化操作将数据从内存中(RAM)转存到磁盘中(ROM)

RAM:用堆栈、寄存器存储的,断电后消失

ROM:磁盘固化存储,断电不消失

用法:

让类实现serializable接口,此类的对象就可以被序列化了。针对对象的对象流:ObjectOutputStream,调用writeObject()/readObject()可以实现序列化、反序列化

反序列化:

在一个序列化的类中,如果不想让某一个变量字段不被序列化,例如银行卡密码,为了安全起见,不希望在网络操作(主要涉及到序列化操作,本地序列化缓存也适用)中被传输,这些信息对应的变量就可以加上transient关键字。换句话说,这个字段的生命周期仅存于调用者的内存中而不会写到磁盘里持久化,获取为null

猜你喜欢

转载自blog.csdn.net/weixin_38500014/article/details/86673862