guava Lists.transform 远程调用的坑

在使用Dubbo进行服务间调用并利用Guava处理数据转换时,遇到RPC远程调用错误,原因在于Guava的Lists.transform方法保存原有列表及转化函数,导致序列化问题。本文提供了解决方案,包括自定义循环或修改转换逻辑。

服务之间调用使用的是dubbo,处理结果是用的guava,debug代码 ,逻辑走完之后,会重复调用两次,然后报错,提示接口没有序列化

具体代码如下:
我处理list的地方:

List<Date> dateList = Lists.newArrayList(Lists.transform(XXXDTOS, new Function<XXXDTOS, Date>() {
                @Override
                public Date apply(XXXDTOS dto) {
                    return dto.getDate();
                }
            }));

dubbo远程调用的报错:
在这里插入图片描述
解决办法:

修改一下转化list的地方:

 List<Date> dateList = Lists.newArrayList(Lists.transform(XXXDTOS, new Function<XXXDTOS, Date>() {
                @Override
                public Date apply(XXXDTOS dto) {
                    return dto.getDate();
                }
            }));

这样就能解决rpc远程调用错误。

问题引起的原因:因为guava Lists.transform 保存的是原有列表和向新列表转化的Function

可以去读一下guava中TransformingRandomAccessList的源码

解决办法呢,有两种:一个就是不用guava 自己循环遍历,另一个就是在转化的时候,复制到一个你需要的,新的对象里边,返回新的对象就如我上边的解决方式

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值