list 去重

最近项目中须要对list集合中的重复值进行处理,大部分是采用两种方法,一种是用遍历list集合判断后赋给另外一个list集合,一种是用赋给set集合再返回给list集合。 可是赋给set集合后,因为set集合是无序的,原先的顺序就打乱了。因此我又想着能不能用set的特性进行去重又不打乱顺序呢? 试了一下,也是能够的,几种方法在不一样状况下都有各自的优点。如今将代码写出来,比较一下。code

//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); 
  }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 //遍历后判断赋给另外一个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); 
  }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 //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");hash

Set set = new  HashSet(); 
     List newList = new  ArrayList(); 
     set.addAll(list);
     newList.addAll(set);

     System.out.println( "去重后的集合: " + newList); 
 }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 //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

List newList = new ArrayList(new HashSet(list)); 

         System.out.println( "去重后的集合: " + newList); 
     }

hashset不进行排序,还有一种方法是用treeset,去重而且按照天然顺序排列,将hashset改成treeset就能够了。(本来的顺序是改变的,只是按照字母表顺序排列而已)遍历

//去重而且按照天然顺序排列 List newList = new ArrayList(new TreeSet(list));方法

相关文章
相关标签/搜索