1:
Hastset은 해시코드를 기준으로 반복 여부를 판단하며, 데이터는 반복되지 않습니다.
Java 코드
/** 목록 순서가 유지되지 않음**/
public static void RemoveDuplicate(ArrayList arlList)
{
HashSet h = new HashSet(arlList)
arlList.clear(); >
arlList.addAll(h); } 2: 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 < list.size() - 1 ; i ++ ) { for ( int j = list.size() - 1 ; j > i; j -- ) { if (list.get(j).equals(list.get(i))) { list.remove(j); } } } System.out.println(list); }
// 删除ArrayList中重复元素 public static void removeDuplicate(List list) { HashSet h = new HashSet(list); list.clear(); list.addAll(h); System.out.println(list); }
// 删除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<List<String>> list1 = (List<List<String>>) map.get("商品入库表"); //表1 入库详细表 //删除list中 数量为 0值 for (Iterator<List<String>> item = list1.iterator(); item.hasNext(); ) { List<String> it = item.next(); System.out.print(it); if (it.get(4).equals("0.0")) { item.remove(); } }