我有以下两个课程
class A {
class InnerA {
private String field;
// getters/setters
}
private Collection<InnerA> collection;
// getters/setters
}
class B {
private String field;
// getters/setters
}
是否可以将A映射到B的集合(A.collection.field应该映射到B.field的集合中)?
我尝试使用自定义转换器,但我只需要管理java.lang.VerifyError:
mapperFactory.getConverterFactory().registerConverter(new CustomConverter<A, Collection<B>>() {
@Override
public Collection<B> convert(
A arg0, Type<? extends Collection<B>> arg1) {
Collection<B> result = new ArrayList<B>();
Iterator<Item> it = arg0.getCollection().iterator();
while(it.hasNext()){
it.next();
result.add(new B());
}
return result;
}
});
结果:
java.lang.VerifyError: Inconsistent args count operand in invokeinterface in method ma.glasnost.orika.generated.Orika_ArrayList_A_Mapper845657274.mapAtoB(Ljava/lang/Object;Ljava/lang/Object;Lma/glasnost/orika/MappingContext;)V at offset 74
at java.lang.Class.getDeclaredConstructors0(Native Method)
at java.lang.Class.privateGetDeclaredConstructors(Class.java:2404)
at java.lang.Class.getConstructor0(Class.java:2714)
at java.lang.Class.newInstance0(Class.java:343)
at java.lang.Class.newInstance(Class.java:325)
答案 0 :(得分:5)
当然你可以映射它,你必须公开InnerA:
List<B> dest = mapper.mapAsList(sourceA.getCollection(), B.class);
如果InnerA不公开,则Orika无法使用
MapperFacade mapper = new ConfigurableMapper() {
@Override
protected void configure(MapperFactory factory) {
factory.registerMapper(new CustomMapper<A, Collection<B>>() {
@Override
public void mapAtoB(A a, Collection<B> b, MappingContext context) { b.addAll(mapperFacade.mapAsList(a.collection, B.class));
for(B item : b) {
item.propertyA = a.propertyA;
}
}
});
factory.registerConcreteType(Collection.class, ArrayList.class);
}
};
final Type<Collection<B>> collectionOfB = new TypeBuilder<Collection<B>>() {}.build();
Collection<B> dest = mapper.map(source, TypeFactory.valueOf(A.class), collectionOfB);