Chinaunix首页 | 论坛 | 博客
  • 博客访问: 132663
  • 博文数量: 46
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 300
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-15 23:00
文章分类

全部博文(46)

文章存档

2018年(18)

2017年(11)

2015年(14)

2014年(3)

我的朋友

分类: Java

2018-01-13 23:53:53

直接上代码

点击(此处)折叠或打开

  1. public class TestArrayListGroupByKey {
  2.  
  3.   public static void main(String[] args) {
  4.     /*1、准备数据**/
  5.     SkuVo sku1 = new SkuVo(1L,"p1",100L);
  6.     SkuVo sku2 = new SkuVo(2L,"p2",101L);
  7.     SkuVo sku3 = new SkuVo(3L,"p3",102L);
  8.     SkuVo sku4 = new SkuVo(3L,"p4",103L);
  9.     SkuVo sku5 = new SkuVo(2L,"p5",100L);
  10.     SkuVo sku6 = new SkuVo(5L,"p6",100L);
  11.  
  12.     List<SkuVo> skuVoList = Arrays.asList(new SkuVo [] {sku1,sku2,sku3,sku4,sku5,sku6});
  13.  
  14.     /*2、分组算法**/
  15.     Map<Long, List<SkuVo>> skuIdMap = new HashMap<>();
  16.     for (SkuVo skuVo : skuVoList) {
  17.       List<SkuVo> tempList = skuIdMap.get(skuVo.getSkuId());
  18.       /*如果取不到数据,那么直接new一个空的ArrayList**/
  19.       if (tempList == null) {
  20.         tempList = new ArrayList<>();
  21.         tempList.add(skuVo);
  22.         skuIdMap.put(skuVo.getSkuId(), tempList);
  23.       }
  24.       else {
  25.         /*某个sku之前已经存放过了,则直接追加数据到原来的List里**/
  26.         tempList.add(skuVo);
  27.       }
  28.     }
  29.  
  30.     /*3、遍历map,验证结果**/
  31.     for(Long skuId : skuIdMap.keySet()){
  32.       System.out.println(skuIdMap.get(skuId));
  33.     }
  34.   }
  35. }
输出结果:

  1. [SkuVo [skuId=1, productName=p1, brandStoreSn=100]]
  2. [SkuVo [skuId=2, productName=p2, brandStoreSn=101], SkuVo [skuId=2, productName=p5, brandStoreSn=100]]
  3. [SkuVo [skuId=3, productName=p3, brandStoreSn=102], SkuVo [skuId=3, productName=p4, brandStoreSn=103]]
  4. [SkuVo [skuId=5, productName=p6, brandStoreSn=100]]
从输出结果看,数据已经按照skuId进行分组了。

阅读(909) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~