在实际开发中我们常常遇到这样的问题,有A、B两个集合,这两个集合的某一个字段是相同的,要把A集合和B进行匹配,然后把A的值赋值给B例如:
//上传图片
List A=multipartRequest.getFiles("fileName");
List C=new ArrayList();
List B=questionInfoService.getTaskList(taskUser.getTaskCode());
for (TQuestionInfo q :B) {
for (MultipartFile t : A) {
if(q.getQuestionNum().equals(t.getOriginalFilename())){
C.add(t);
}
q.setTTaskQuestionUserPic(C);
}
这样是对但是这样处理有个很严重的问题,这样循环是N*N的,意思是如果A有一万条数据B有一万条数据那么这个循环会循环一亿次,如果A和B各有十万条数据那结果我就不敢想象。
对于这样的情况我选择了封装一个集合,比如说把A集合封装为Map > 然后循环B集合 用相同的字段当做键值来取例如:
//封装为Map
public Map> getTaskQuetionUserMapPic(List list){
Map> map = new HashMap>();
List childList=null;
Iterator it=list.iterator();
TTaskQuestio