假如有两张表t1和t2,t1是属性是id name,t2是id sex。两张表id是关联的。假如有两个集合,C1和C2,C1存着T1的数据,C2存着T2的数据。
此时我们想,将C1和C2的数据整合到一起变成新的对象,属性为id ,name,sex。
一般我们都会使用for(){for(){}}两个for嵌套,这种效率是很慢的,如果集合是10条数据,则会需要遍历10*10=100次。
这是后,我们会使用构造字典。
首先,用C1为例,我们不要用list而是使用Map
Map<String,Object> dimensionMap=new HashMap();
for(int i=0;i<dimensionList.size();i++){ ErpDimensionUpdate dimensionUpdate=(ErpDimensionUpdate) dimensionList.get(i); dimensionMap.put(dimensionUpdate.getItemName(),dimensionUpdate); }
String存放id,Object存放对象
for(int i=0;i<productList.size();i++){ AddProdWeight addProdWeight=(AddProdWeight) productList.get(i); ErpDimensionUpdate dimensionUpdate=(ErpDimensionUpdate) dimensionMap.get(addProdWeight.getProdNum()); addProdWeight.setUnitWgt(Integer.parseInt(dimensionUpdate.getReference2())); addList.add(addProdWeight);通过Map的key,我们能很快找到对象,并给其赋值,假如10条数据,我们总共只需要遍历20次,这样效率就很高。