Collections集合工具类常用的方法
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> );
//将集合中元素按照指定规则排
addAll()方法
package _5Collections集合工具类; import java.util.ArrayList;
import java.util.Collections; /**
* @Author Admin
* @Classname DemoCollections
* @Package _5Collections集合工具类
* @GreatDate 2020/04/19 17:29:01
* @Description TODO 演示Collections集合工具类
*/
public class DemoCollectionsAddAll {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
//往集合中添加元素
list.add("0");
list.add("b");
list.add("c");
list.add("x");
list.add("x");
list.add("u");
list.add("K"); System.out.println(list);//[0, b, c, x, x, u, K]
/*
public static <T> boolean addAll(Collection<T> c, T... elements);
往集合中添加一些元素[添加多个元素]。
*/
Collections.addAll(list,"a","b","l");
System.out.println(list); }
}
sort(List<T> list)方法,实现Comparable接口
public static <T> void sort(List<T> list);
//将集合中元素按照默认规则排序。
注意:
sort(List<T>List)使用前提
/* 被排序的集合里边存储的元素,必须实现comparable接口,
因此覆写comparable接口中的方法 compareTo(),可以重新定义排序的规则。
*/
comparable 接口中的排序规则:
自己(this)-参数:升序,反之,就是降序.
实例:
package _5Collections集合工具类; import java.util.ArrayList;
import java.util.Collections; /**
* @Author Admin
* @Classname DemoCollectionsAddSort
* @Package _5Collections集合工具类
* @GreatDate 2020/04/19 19:32:10
* @Description TODO 演示Collectionsl类的Sort()方法
*/
/*
public static <T> void sort(List<T> list);
将集合中元素按照默认规则排序。
注意:
sort(List<T>List)使用前提
被排序的集合里边存储的元素,必须实现comparable接口,
因此覆写comparable接口中的方法compareTo(),可以重新定义排序的规则。
comparable接口中的排序规则:
自己(this)-参数:升序,反之,就是降序. */
public class DemoCollectionsComparableSort {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<>();
list.add(1);
list.add(6);
list.add(8);
list.add(5);
System.out.println(list);//[1, 6, 8, 5]
System.out.println("---------------------------");
Collections.sort(list);//默认是升序
System.out.println(list);
System.out.println("---------------------------");
ArrayList<String> list01 = new ArrayList<>();
list01.add("b");
list01.add("a");
list01.add("c");
list01.add("A"); System.out.println(list01);//[b, a, c, A]
System.out.println("---------------------------");
Collections.sort(list01);//默认是升序
System.out.println(list01);
System.out.println("---------------------------"); ArrayList<Person> list02 = new ArrayList<>();
list02.add(new Person("张三", 29));
list02.add(new Person("李四", 23));
list02.add(new Person("王五", 19));
list02.add(new Person("赵六", 28));
System.out.println(list02);
//排序前:[Person{name='张三', age=29}, Person{name='李四', age=23}, Person{name='王五', age=19}, Person{name='赵六', age=28}]
System.out.println("---------------------------");
Collections.sort(list02);
System.out.println(list02);//升序
//覆写comparable接口中的方法compareTo()后,
//[Person{name='王五', age=19}, Person{name='李四', age=23}, Person{name='赵六', age=28}, Person{name='张三', age=29}]
} }
实体类:
package _5Collections集合工具类; /**
* @Author Admin
* @Classname Person
* @Package _2Set集合._3HashCode哈希值
* @GreatDate 2020/04/19 09:13:54
* @Description TODO 演示实体类
*/ public class Person implements Comparable<Person>{
private String name;
private int age; 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;
}
//覆写排序的规则
@Override
public int compareTo(Person o) {
// return 0;//认为元素都是相同的
//自定义比较的规则,如:比较两个人的年龄(this,参数Person) //return this.getAge() - o.getAge();//年龄升序排序
return o.getAge() - this.getAge();//年龄降序序排序
}
}
sort(List<T> list,Comparator<? super T>实现Comparator接口
public static <T> void sort(List<T> list,Comparator<? super T> );
//将集合中元素按照指定规则排序
//Comparator接口中的排序规则:
// o1 - o2 :升序排序,反之,就是降序排序
Comparator和Comparable两个接口的区别:
Comparable:自己(this)和别人(参数)比较,自己需要实现Comparable接口,重写比较的规则compareTo方法
Comparator:相当于找一个第三方的裁判,比较两个。
package _5Collections集合工具类; import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator; /**
* @Author Admin
* @Classname DemoCollectionCopartorSort
* @Package _5Collections集合工具类
* @GreatDate 2020/04/19 21:18:13
* @Description TODO 第二种排序方法
*/
/*
public static <T> void sort(List<T> list,Comparator<? super T> );
将集合中元素按照指定规则排序
Comparator和Comparable两个接口的区别:
Comparable:自己(this)和别人(参数)比较,自己需要实现Comparable接口,重写比较的规则compareTo方法
Comparator:相当于找一个第三方的裁判,比较两个。
Comparator接口中的排序规则:
o1 - o2 :升序排序,反之,就是降序排序
*/
public class DemoCollectionCopartorSort {
public static void main(String[] args) {
ArrayList<Integer> list = new ArrayList<>();
list.add(1);
list.add(6);
list.add(8);
list.add(5);
System.out.println(list);//[1, 6, 8, 5] Collections.sort(list, new Comparator<Integer>() {
//覆写比较的规则
@Override
public int compare(Integer o1, Integer o2) {
// return o1 - o2;//升序排序
return o2 - o1;//降序排序
}
});
System.out.println(list);
System.out.println("------------------"); ArrayList<Student> list1 = new ArrayList<>();
list1.add(new Student("张三", 26));
list1.add(new Student("李四", 28));
list1.add(new Student("王五", 22));
list1.add(new Student("赵六", 22));
/*//一个规则
Collections.sort(list1, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
return o1.getAge() - o2.getAge();//按照年龄的升序排序
}
});*/
//多个规则;扩展,了解
Collections.sort(list1, new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
//按照年龄的升序排序
int result = o1.getAge() - o2.getAge();
//如果两个人年龄相同,再使用姓名比较第一个字
if (result == 0) {
result = o1.getName().charAt(0) - o2.getName().charAt(0);
}
return result;
}
});
System.out.println(list1);
}
}
实体类
package _5Collections集合工具类; /**
* @Author Admin
* @Classname Student
* @Package _5Collections集合工具类
* @GreatDate 2020/04/19 21:56:29
* @Description TODO
*/
public class Student {
private String name;
private int age; public Student() {
} @Override
public String toString() {
return "Student{" +
"name='" + name + '\'' +
", age=" + age +
'}';
} public Student(String name, int age) {
this.name = name;
this.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;
}
}
Collections集合工具类常用的方法的更多相关文章
- 可变参数和Collections集合工具类
可变参数 /** * 可变参数:jdk1.5后出现的新特性 * 使用前期: * 当方法的参数列表数据类型已经确定的时候但是参数的个数不确定的时候就可以使用可变参数 * 使用格式:定义方法的时候使用 * ...
- java第十九天,Collections集合工具类的使用
Collections Java中集合都实现了Collection接口,那么针对集合一些特定的功能,有没有一个接口或类能够统一的集成一些集合必要的功能呢?当然能.它就是--Collections集合工 ...
- Collections集合工具类,集合嵌套,集合综合案例斗地主
1 Collections集合工具类 (可以对比Arrays工具类共同记忆) 常用方法: 例: import java.util.ArrayList; import java.util.Collect ...
- Collections集合工具类的常用方法
Collections集合工具类的方法 addAll与shuffle import java.util.ArrayList; import java.util.Collections; /* - ja ...
- [Guava学习笔记]Collections: 集合工具类
我的技术博客经常被流氓网站恶意爬取转载.请移步原文:http://www.cnblogs.com/hamhog/p/3861431.html,享受整齐的排版.有效的链接.正确的代码缩进.更好的阅读体验 ...
- Collections集合工具类的方法_sort(List)和sort(List,Comparator)方法
Comparator比较器 我们还是先研究这个方法 public static <T> void sort(List<T> list):将集合中元素按照默认规则排序. 不过这次 ...
- 可变参数和Collections集合工具类的方法_addAll&shuffle
可变参数 可变参数:是JDK1.5之后出现的新特性 使用前提:当方法的参数列表数据类型已经确定,但是参数的个数不确定,就可以使用可变参数 使用格式:定义方法时使用 ~修饰符 返回值类型 方法名(数据类 ...
- Collections 集合工具类
集合工具类 包括很多静态方法来操作集合list 而Collections则是集合类的一个工具类/帮助类,其中提供了一系列静态方法,用于对集合中元素进行排序.搜索以及线程安全等各种操作. 1) 排序( ...
- Collections集合工具类
一.Collection与Collections Collection 是所有单列集合的根接口 Collection 是操作集合的工具类 二.Collections中常见的方法:(大都是static方 ...
随机推荐
- android学习笔记——使用QuickContactBadge关联联系人
本文大部分内容来自<疯狂android讲义>. QuickContactBadge继承了ImageView,因此它的本质也是图片,也可以通过android:src属性指定它显示的图片.Qu ...
- SpeedButton
SpeedButton是一个图形控件,本身没有句柄.因此它不能具有焦点.你可以使用TBitBtn,调整一些属性,可以使他们的外形很接近. 只有从TWinControl派生的控件,才具有Handle.你 ...
- Unity 随机地图房间通道生成
之前的博客中已经说了随机房间生成: https://www.cnblogs.com/koshio0219/p/12604383.html 但实现房间生成只是整个地图生成最初最简单的一步.下面讨论如何随 ...
- 1/13 update
小组这几天的update大多都集中在UI方面: 答题界面更改了 放弃和提交按钮: 结果界面进行了颜色的调整,其中没有wordToAdd成员的不现实增加到单词本按钮: 分享结果增加APP的连接:
- Cobalt Stike使用教程
目录: 安装与连接 监听器Listner 基本使用方法--Cobalt Strike生成后门 Beacon详解 菜单栏与视图 文件管理与进程管理 浏览器代理 Cobalt Strike扩展 提权 横向 ...
- niuke---勾股定理
勾股定理------: 当其中一个数a大于1并且为奇数时即a=2*n+1, 那么另外两个数分别为 b=2*n*n+2*n; c=b+1; 当a为大于等于4的偶数时,即a=2*n时,那么另外两个数分 ...
- python之excel表操作
python对excel表操作主要用到三个库,xlrd,xlwt,xlutils,分别用于excel表读,写,修改操作,以下将一个简单介绍 一.生成excel表:xlwt类 新建excel表,并写入数 ...
- EF-相关查询(逐渐完善)
linq查询方式 多条件查询 内连接 左连接 可以执行sql含事务
- nodejs之https双向认证
说在前面 之前我们总结了https的相关知识,如果不懂可以看我另一篇文章:白话理解https 有关证书生成可以参考:自签证书生成 正题 今天使用nodejs来实现https双向认证 话不多说,直接进入 ...
- 高级数据结构---赫(哈)夫曼树及java代码实现
我们经常会用到文件压缩,压缩之后文件会变小,便于传输,使用的时候又将其解压出来.为什么压缩之后会变小,而且压缩和解压也不会出错.赫夫曼编码和赫夫曼树了解一下. 赫夫曼树: 它是一种的叶子结点带有权重的 ...