但是赋给set凑集后,由于set凑集是无序的,原来的顺序就打乱了。以是我又想着能不能用set的特性进行去重又不打乱顺序呢?
试了一下,也是可以的,几种方法在不同情形下都有各自的上风。现在将代码写出来,比较一下。
//set凑集去重,不打乱顺序 public static void main(String[] args){ List<String> list = new ArrayList<String>(); list.add(\公众aaa\"大众); list.add(\"大众bbb\"大众); list.add(\"大众aaa\公众); list.add(\"大众aba\"大众); list.add(\公众aaa\"大众); Set set = new HashSet(); List newList = new ArrayList(); for (String cd:list) { if(set.add(cd)){ newList.add(cd); } } System.out.println( \公众去重后的凑集: \"大众 + newList); }123456789101112131415161718 //遍历后判断赋给另一个list凑集 public static void main(String[] args){ List<String> list = new ArrayList<String>(); list.add(\公众aaa\"大众); list.add(\"大众bbb\"大众); list.add(\"大众aaa\"大众); list.add(\"大众aba\公众); list.add(\"大众aaa\"大众); List<String> newList = new ArrayList<String>(); for (String cd:list) { if(!newList.contains(cd)){ newList.add(cd); } } System.out.println( \公众去重后的凑集: \公众 + newList); }1234567891011121314151617 //set去重 public static void main(String[] args){ List<String> list = new ArrayList<String>(); list.add(\"大众aaa\"大众); list.add(\"大众bbb\公众); list.add(\"大众aaa\"大众); list.add(\"大众aba\"大众); list.add(\"大众aaa\"大众); Set set = new HashSet(); List newList = new ArrayList(); set.addAll(list); newList.addAll(set); System.out.println( \"大众去重后的凑集: \"大众 + newList); }12345678910111213141516 //set去重(缩减为一行) public static void main(String[] args){ List<String> list = new ArrayList<String>(); list.add(\"大众aaa\公众); list.add(\"大众bbb\"大众); list.add(\"大众aaa\"大众); list.add(\"大众aba\"大众); list.add(\"大众aaa\"大众); List newList = new ArrayList(new HashSet(list)); System.out.println( \"大众去重后的凑集: \"大众 + newList); }12345678910111213
hashset不进行排序,还有一种方法是用treeset,去重并且按照自然顺序排列,将hashset改为treeset就可以了。(原来的顺序是改变的,只是按照字母表顺序排列而已)
//去重并且按照自然顺序排列List newList = new ArrayList(new TreeSet(list));