一:
hastset根据hashcode判断是否重复,数据不会重复
java代码
/** list order not maintained **/
public static void removeduplicate(arraylist arllist)
{
hashset h = new hashset(arllist);
arllist.clear();
arllist.addall(h);
}
二:
通过hashset的add方法判断是否已经添加过相同的数据,如果已存在相同的数据则不添加
java代码
/** list order maintained **/
public static void removeduplicatewithorder(arraylist arllist)
{
set set = new hashset();
list newlist = new arraylist();
for (iterator iter = arllist.iterator(); iter.hasnext(); )
{
object element = iter.next();
if (set.add(element)) newlist.add(element);
}
arllist.clear();
arllist.addall(newlist);
}
以下来自网络:
方法一:循环元素删除
// 删除arraylist中重复元素
public static void removeduplicate(list list) {
for ( int i = 0 ; i i; j -- ) {
if (list.get(j).equals(list.get(i))) {
list.remove(j);
}
}
}
system.out.println(list);
}
方法二:通过hashset剔除
// 删除arraylist中重复元素
public static void removeduplicate(list list) {
hashset h = new hashset(list);
list.clear();
list.addall(h);
system.out.println(list);
}
方法三: 删除arraylist中重复元素,保持顺序
// 删除arraylist中重复元素,保持顺序
public static void removeduplicatewithorder(list list) {
set set = new hashset();
list newlist = new arraylist();
for (iterator iter = list.iterator(); iter.hasnext();) {
object element = iter.next();
if (set.add(element))
newlist.add(element);
}
list.clear();
list.addall(newlist);
system.out.println( remove duplicate + list);
}
自己使用: 删除 “0.0”的值
list list1 = (list) map.get(商品入库表); //表1 入库详细表
//删除list中 数量为 0值
for (iterator item = list1.iterator(); item.hasnext(); ) {
list it = item.next();
system.out.print(it);
if (it.get(4).equals(0.0)) {
item.remove();
}
}
链接地址:http://iteye.blog.163.com/blog/static/186308096201302565345510/