-
java.utils.Collections
是集合工具类,用来对集合进行操作。部分方法如下:
-
public static <T> boolean addAll(Collection<T> c, T... elements)
:往集合中添加一些元素。 -
public static void shuffle(List<?> list) 打乱顺序
:打乱集合顺序。 -
public static <T> void sort(List<T> list)
:将集合中元素按照默认规则排序。 -
public static <T> void sort(List<T> list,Comparator<? super T> )
:将集合中元素按照指定规则排序。
public static void main(String[] args) { ArrayList<String> list = new ArrayList<>(); //添加多个元素 Collections.addAll(list,"a","c","b","d"); System.out.println(list); //打乱集合中元素的顺序 Collections.shuffle(list); System.out.println(list); //sort 将集合中的元素按照默认的顺序排序 只能使用list集合或者实现了list接口 Collections.sort(list); System.out.println(list); }
()如何进行排序呢?
两个对象比较的结果有三种:大于,等于,小于。
如果要按照升序排序, 则o1 小于o2,返回(负数),相等返回0,01大于02返回(正数)
如果要按照降序排序 则o1 小于o2,返回(正数),相等返回0,01大于02返回(负数)
public class CollectionsDemo3 { public static void main(String[] args) { ArrayList<String> list = new ArrayList<String>(); list.add("cba"); list.add("aba"); list.add("sba"); list.add("nba"); //排序方法 按照第一个单词的降序 Collections.sort(list, new Comparator<String>() { @Override public int compare(String o1, String o2) { return o2.charAt(0) - o1.charAt(0); } }); System.out.println(list); } }
创建一个人类,存储到ArrayList集合中完成指定排序操作。
第一种:将人类实现Comparable<Person>接口,并重写compareTo()方法
@Override public int compareTo(Person o) { //自定义比较规则 按年龄shengx比较 return this.getAge()-o.getAge(); }
第二种:使用内部类方式 new Comparator()接口,重写compare方法
Lambda表达式简写:Collections.sort(people, (o1,o2) -> o1.getAge()-o2.getAge() );
public class Demo02Sort { public static void main(String[] args) { ArrayList<Person> people = new ArrayList<>(); Person p1 = new Person("hdh", 20); Person p2 = new Person("xj", 19); Collections.addAll(people,p1,p2); Collections.sort(people, new Comparator<Person>() { @Override public int compare(Person o1, Person o2) { return o1.getAge()-o2.getAge(); } }); System.out.println(people); } }