Dubbo协议传输后对象为NULL,为什么?

在使用Dubbo+Zookepper做微服务项目时通过Dubbo协议传输后对象为NULL,这到底是怎么回事呢?

java 的transient关键字为我们提供了便利,你只需要实现Serilizable接口,将不需要序列化的属性前添加关键字transient,序列化对象的时候,这个属性就不会序列化到指定的目的地中。

所以我们的问题也就有了答案:

在被transient关键字修饰后:
(1)一旦变量被transient修饰,变量将不再是对象持久化的一部分,该变量内容在序列化后无法获得访问。

(2)transient关键字只能修饰变量,而不能修饰方法和类。注意,本地变量是不能被transient关键字修饰的。变量如果是用户自定义类变量,则该类需要实现Serializable接口。

(3)被transient关键字修饰的变量不再能被序列化,一个静态变量不管是否被transient修饰,均不能被序列化。
而我们的Dubbo在做rpc的时候,会做两台主机的通讯,需要通讯则需要传输字节数据。所以就需要用到序列化,没有序列化的字段就不会被传输。

发布了12 篇原创文章 · 获赞 10 · 访问量 420

猜你喜欢

转载自blog.csdn.net/weixin_43193358/article/details/105623677
今日推荐