之前谷咕咕写程序的时候一直在想,list的遍历和 *** 作怎么都和数组差不多,那我和数组一样直接用for不就行了?
直到我碰到下面的业务场景的时候,踩了的坑!,和大家分享一下。
介绍一样需求:
谷咕咕通过,查询到所有的活动信息。里面的参数用于模糊查询,可以无视。
List lists=activityService.listall("");
list拿到了数据,谷咕咕想要筛选掉过期的活动(活动结束时间和当前时间比较)
坑:当时谷咕咕想那我用for循环遍历集合,然后判断每项的endtime与当前时间,然后remove。这么想好像没什么问题,但是查询结果却是乱七八糟的数据。
后来想如果用for循环,那我就再创建一个list集合接受数据可以实现,但是可以说是非常暴力的方式
后来谷咕咕打断点看了一下,才发现,remove的时候,list的长度就变了,数据发生了移动,所以一定会出现问题
这个时候想到了可以使用iterator,发现可以正常的处理数据量。
@Test public void test5() throws ParseException { List lists=activityService.listall(""); Date today=new Date(); Iterator it = lists.iterator(); while (it.hasNext()) { ActivityInfo str = (ActivityInfo) it.next(); if (today.getTime()总结:对于list集合的 *** 作还是用iterator ,当然如果不改变的list的长度,且不考虑效率,for循环也是没有问题的。 不会只有谷咕咕自己踩了这样的坑?
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)