记录通过Map将list中包含相同字段的对象存放到一起,不同对象的分开

本文介绍了一种通过Java实现的商品浏览记录整理方法,该方法利用Map结构来存储按日期归类的浏览记录,并提供了将Map转换为List的方法以便进一步处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

app添加一个新功能,浏览商品记录展示,根据日期排序,后台给出的接口是一个数组,里面直接是所有浏览商品数据,日期相同的不相同的都在这个数组里,新建了一个实体类Tracks,将请求到的数据放到list中,之后需要将相同的数据出来,代码如下:

  Tracks track;
  Map<String, List<Tracks>> resultMap = new TreeMap<String, List<Tracks>>(); // 最终要的结
  for (int i = 0; i < AllTracks.size(); i++) {
track = AllTracks.get(i);
//是否已经存在对应的日期
if (resultMap.containsKey(track.getVisitTime())) {
resultMap.get(track.getVisitTime()).add(track);
} else {
List<Tracks> list = new ArrayList<Tracks>();
list.add(track);
resultMap.put(track.getVisitTime(), list);
}
}
  List<List<Tracks>> tss=mapToList(resultMap);//将map转回list

  mapToList方法:

 public static List<List<Tracks>> mapToList(Map map) {
List<List<Tracks>> list = new ArrayList<List<Tracks>>();
Iterator iter = map.entrySet().iterator(); // 获得map的Iterator
while (iter.hasNext()) {
Entry entry = (Entry) iter.next();

                        //取出所有值
list.add((List<Tracks>) entry.getValue());
}
return list;
  }

 //此处注意日期排序,视情况选择Map类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值