Java难点 | Collections集合工具类
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java难点 | Collections集合工具类相关的知识,希望对你有一定的参考价值。
Collections集合工具类
addAll和shuffle方法
代码示例
/*
public static <T> boolean addAll(collection<T> c,T...elements):往集合添加多个元素
public static void shuffle(List<?> list) 打乱顺序:打乱集合顺序
*/
public class aa
public static void main(String[] args)
ArrayList<String> list = new ArrayList<>();
//往集合添加多个元素
list.add("a");
list.add("b");
list.add("c"); //要一个一个加
//public static <T> boolean addAll(collection<T> c,T...elements):往集合添加多个元素
Collections.addAll(list,"a","b","c"); //它的参数是可变参数,可以传递任意多个元素
System.out.println(list); //[a, b, c, a, b, c]
//public static void shuffle(List<?> list) 打乱顺序:打乱集合顺序
Collections.shuffle(list);
System.out.println(list); //[c, a, b, b, c, a] 每次重复的都不一样
sort方法1
代码示例
/*
public static <T> void sort(List<T> list):将集合中元素按照,默认规则排序 (里面只能传递list集合不能set)
注意事项:
sort(List<T> list)使用前提 (传递的是自定义类型的话)
被排序的集合里面存储的元素,必须实现Comparable接口,重写接口中的方法compareTo定义排序的规则
Comparable排序规则:
自己(this)-参数;升序
*/
public class bb
public static void main(String[] args)
ArrayList<Integer> list01 = new ArrayList<>();
list01.add(1);
list01.add(3);
list01.add(2);
System.out.println(list01);//[1, 3, 2]
//public static <T> void sort(List<T> list):将集合中元素按照,默认规则排序
Collections.sort(list01); // 默认是升序
System.out.println(list01); //[1, 2, 3]
ArrayList<String> list02 = new ArrayList<>();
Collections.addAll(list02,"a","c","b");
System.out.println(list02); //[a, c, b]
Collections.sort(list02); // 默认是升序
System.out.println(list02); //[a, b, c]
//对自定义类型排序
ArrayList<person> list03 = new ArrayList<>();
list03.add(new person("张三",18));
list03.add(new person("李四",20));
list03.add(new person("王五",15));
System.out.println(list03);//[personname=张三, age=18, personname=李四, age=20, personname=王五, age=15]
Collections.sort(list03);
System.out.println(list03);//[personname=王五, age=15, personname=张三, age=18, personname=李四, age=20]
public class person implements Comparable<person>
private String name;
private int age;
//重写排序的规则
@Override
public int compareTo(person o)
// return 0; //认为元素都是相同的
//自定义比较的规则,比较两个人的年龄(this,person)
return this.getAge()-o.getAge(); //年龄升序排序
// return o.getAge()-this.getAge(); //年龄降序排序
public person()
public person(String name, int age)
this.name = name;
this.age = age;
@Override
public String toString()
return "person" +
"name=" + name + \\ +
", age=" + age +
;
public String getName()
return name;
public void setName(String name)
this.name = name;
public int getAge()
return age;
public void setAge(int age)
this.age = age;
sort方法2
代码示例
public class cc
public static void main(String[] args)
ArrayList<Integer> list01 = new ArrayList<>();
list01.add(1);
list01.add(3);
list01.add(2);
System.out.println(list01);//[1, 3, 2]
Collections.sort(list01, new Comparator<Integer>() //使用匿名内部类
//重写比较的规则
@Override
public int compare(Integer o1, Integer o2)
// return o1-o2;//升序
return o2-o1;//降序
);
System.out.println(list01); //[3, 2, 1]
//比较自定义类型
ArrayList<Student> list02 = new ArrayList<>();
list02.add(new Student("迪丽热巴",18));
list02.add(new Student("古力娜扎",20));
list02.add(new Student("杨幂",17));
System.out.println(list02);
//[Studentname=迪丽热巴, age=18, Studentname=古力娜扎, age=20, Studentname=杨幂, age=17]
Collections.sort(list02, new Comparator<Student>()
@Override
public int compare(Student o1, Student o2)
//按照年龄升序排序
return o1.getAge()- o2.getAge();
);
System.out.println(list02);
//[Studentname=杨幂, age=17, Studentname=迪丽热巴, age=18, Studentname=古力娜扎, age=20]
public class Student
private String name;
private int age;
public Student(String name, int age)
this.name = name;
this.age = age;
public Student()
@Override
public String toString()
return "Student" +
"name=" + name + \\ +
", age=" + age +
;
public String getName()
return name;
public void setName(String name)
this.name = name;
public int getAge()
return age;
public void setAge(int age)
this.age = age;
以上是关于Java难点 | Collections集合工具类的主要内容,如果未能解决你的问题,请参考以下文章
Java集合框架--Collections工具类的使用 & Java集合框架总结
Java源码分析集合框架-Collections工具类-Arrays工具类