在使用Dubbo+Zookepper做微服务项目时通过Dubbo协议传输后对象为NULL,这到底是怎么回事呢?
java 的transient关键字为我们提供了便利,你只需要实现Serilizable接口,将不需要序列化的属性前添加关键字transient,序列化对象的时候,这个属性就不会序列化到指定的目的地中。
所以我们的问题也就有了答案:
在被transient关键字修饰后:
(1)一旦变量被transient修饰,变量将不再是对象持久化的一部分,该变量内容在序列化后无法获得访问。
(2)transient关键字只能修饰变量,而不能修饰方法和类。注意,本地变量是不能被transient关键字修饰的。变量如果是用户自定义类变量,则该类需要实现Serializable接口。
(3)被transient关键字修饰的变量不再能被序列化,一个静态变量不管是否被transient修饰,均不能被序列化。
而我们的Dubbo在做rpc的时候,会做两台主机的通讯,需要通讯则需要传输字节数据。所以就需要用到序列化,没有序列化的字段就不会被传输。