服务之间调用使用的是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 自己循环遍历,另一个就是在转化的时候,复制到一个你需要的,新的对象里边,返回新的对象就如我上边的解决方式