Java操作集合工具類Collections使用詳解
這篇文章主要介紹了java操作集合工具類Collections使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
Collections是一個(gè)操作Set、List和Map等集合的工具類。
Collections中提供了大量方法對(duì)集合元素進(jìn)行排序、查詢和修改等操作,還提供了對(duì)集合對(duì)象設(shè)置不可變、對(duì)集合對(duì)象實(shí)現(xiàn)同步控制等方法。
排序操作:
- reverse(List):反轉(zhuǎn)List中元素的順序;
- shuffle(List):對(duì)List集合元素進(jìn)行隨機(jī)排序;
- sort(List):根據(jù)元素的自然順序?qū)χ付↙ist集合元素按升序排序;
- sort(List,Comparator):根據(jù)指定的Conparator產(chǎn)生的順序?qū)ist集合進(jìn)行排序;
- swap(List,int,int):將指定List集合中的i和j處的元素進(jìn)行交換;
package collections;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class Test5 {
public static void main(String[] args) {
List<Integer> list1 = new ArrayList<Integer>();
list1.add(2);
list1.add(1);
list1.add(4);
list1.add(3);
System.out.println("原始的list1:"+list1);
Collections.reverse(list1);
System.out.println("反轉(zhuǎn)之后的list1:"+list1);
Collections.sort(list1);
System.out.println("排序之后的list1:"+list1);
Collections.shuffle(list1);
System.out.println("打亂之后的list1:"+list1);
List<Student> list2 = new ArrayList<Student>();
Student s1 = new Student("tom",21);
Student s2 = new Student("jack",16);
Student s3 = new Student("bob",32);
list2.add(s1);
list2.add(s2);
list2.add(s3);
Collections.sort(list2, new Student());
System.out.println("按照年齡降序進(jìn)行排序:");
for(Student stu:list2) {
System.out.println("name="+stu.name+","+"age="+stu.age);
}
}
}
class Student implements Comparator<Student>{
String name;
int age;
public Student(){}
public Student(String name,int age){
this.name = name;
this.age = age;
}
@Override
public int compare(Student o1, Student o2) {
// TODO Auto-generated method stub
if(o1.age>o2.age) {
return -1;
}else if (o1.age<o2.age) {
return 1;
}else {
return 0;
}
}
}
輸出:
原始的list1:[2, 1, 4, 3] 反轉(zhuǎn)之后的list1:[3, 4, 1, 2] 排序之后的list1:[1, 2, 3, 4] 打亂之后的list1:[1, 3, 2, 4] 按照年齡降序進(jìn)行排序: name=bob,age=32 name=tom,age=21 name=jack,age=16
查找、替換操作:
- Object.max(Collection):根據(jù)元素的自然順序返回指定集合中的最大元素;
- Object.max(Collection,Comparator):根據(jù)Comparator指定的順序,返回指定集合中的最大元素;
- Object.min(Collection):根據(jù)元素的自然順序返回指定集合中的最小元素;
- Object.max(Collection):根據(jù)Comparator指定的順序,返回指定集合中的最小元素;
- int frequency(Collection,Object):返回指定集合中指定元素的出現(xiàn)次數(shù);
- boolean replaceAll(List list,Object oldVal,object newVal):使用新值替換原來(lái)的值;
package collections;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class Test5 {
public static void main(String[] args) {
List<Integer> list1 = new ArrayList<Integer>();
list1.add(2);
list1.add(1);
list1.add(4);
list1.add(3);
list1.add(1);
System.out.println(list1);
System.out.println(Collections.max(list1));
System.out.println(Collections.min(list1));
System.out.println(Collections.frequency(list1,1));
System.out.println(Collections.replaceAll(list1, 1,2));
System.out.println(list1);
List<Student> list2 = new ArrayList<Student>();
Student s1 = new Student("tom",21);
Student s2 = new Student("jack",16);
Student s3 = new Student("bob",32);
list2.add(s1);
list2.add(s2);
list2.add(s3);
for(Student stu:list2) {
System.out.println("name="+stu.name+","+"age="+stu.age);
}
System.out.println(Collections.max(list2,new Student()).name
+"/"+Collections.max(list2,new Student()).age);
System.out.println(Collections.min(list2,new Student()).name
+"/"+Collections.min(list2,new Student()).age);
// Collections.sort(list2, new Student());
// System.out.println("按照年齡降序進(jìn)行排序:");
// for(Student stu:list2) {
// System.out.println("name="+stu.name+","+"age="+stu.age);
// }
}
}
class Student implements Comparator<Student>{
String name;
int age;
public Student(){}
public Student(String name,int age){
this.name = name;
this.age = age;
}
@Override
public int compare(Student o1, Student o2) {
// TODO Auto-generated method stub
if(o1.age>o2.age) {
return 1;
}else if (o1.age<o2.age) {
return -1;
}else {
return 0;
}
}
}
輸出:
[2, 1, 4, 3, 1] 4 1 2 true [2, 2, 4, 3, 2] name=tom,age=21 name=jack,age=16 name=bob,age=32 bob/32 jack/16
同步控制:Collections中提供了多個(gè)synchronizedXxx()方法,該方法可以使指定集合包裝成線程同步的集合,從而可以解決多線程并發(fā)訪問(wèn)集合時(shí)線程安全問(wèn)題。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java中Collections.emptyList()的注意事項(xiàng)
- Java Collections類操作集合詳解
- java Collections 排序--多條件排序?qū)嵗?/a>
- Java后臺(tái)通過(guò)Collections獲取list集合中最大數(shù),最小數(shù)代碼
- Java集合框架Collections原理及用法實(shí)例
- Java Collection集合遍歷運(yùn)行代碼實(shí)例
- Java Collections.sort()排序代碼案例
- Java Arrays.sort和Collections.sort排序?qū)崿F(xiàn)原理解析
- Java Collection集合iterator方法解析
- java中Collections.sort排序詳解
- 詳解JAVA中的Collection接口和其主要實(shí)現(xiàn)的類
- Java源碼解析之接口Collection
相關(guān)文章
org.apache.ibatis.binding.BindingException異常報(bào)錯(cuò)原因以及詳細(xì)解決方案
這篇文章主要給大家介紹了關(guān)于org.apache.ibatis.binding.BindingException異常報(bào)錯(cuò)原因以及詳細(xì)解決方案的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
Java實(shí)現(xiàn)Html轉(zhuǎn)Pdf的方法
這篇文章主要介紹了Java實(shí)現(xiàn)Html轉(zhuǎn)Pdf的方法,實(shí)例分析了java基于ITextRenderer類操作頁(yè)面及系統(tǒng)自帶字體生成pdf文件的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
詳解java實(shí)現(xiàn)HTTP請(qǐng)求的三種方式
這篇文章主要介紹了java實(shí)現(xiàn)HTTP請(qǐng)求的三種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
java 音頻轉(zhuǎn)換wav格式標(biāo)準(zhǔn)音頻的操作
這篇文章主要介紹了java 音頻轉(zhuǎn)換wav格式標(biāo)準(zhǔn)音頻的操作,主要是使用ffmpeg命令進(jìn)行轉(zhuǎn)換,該工具類主要是為了將各類音頻轉(zhuǎn)為wav標(biāo)準(zhǔn)格式,其中可以調(diào)節(jié)采樣率、聲道數(shù)等指標(biāo),依賴maven環(huán)境,需要的朋友可以參考下2021-10-10
基于Springboot疫苗接種行程管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
本文主要介紹了基于Springboot實(shí)現(xiàn)的疫苗接種行程管理系統(tǒng)的示例代碼,系統(tǒng)主要實(shí)現(xiàn)個(gè)人疫苗接種管理、行程管理、病史管理、風(fēng)險(xiǎn)地區(qū)管理、核酸檢測(cè)報(bào)告結(jié)果上報(bào)、疫情新聞管理等功能,需要的可以參考一下2022-03-03
Spring的實(shí)例工廠方法和靜態(tài)工廠方法實(shí)例代碼
這篇文章主要介紹了Spring的實(shí)例工廠方法和靜態(tài)工廠方法實(shí)例代碼,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
SpringBoot遠(yuǎn)程訪問(wèn)redis服務(wù)器問(wèn)題剖析
使用了SpringBoot的項(xiàng)目,在遠(yuǎn)程連接Redis服務(wù)器時(shí),會(huì)遇倒一些小問(wèn)題,下面通過(guò)本文給大家全面解析SpringBoot遠(yuǎn)程訪問(wèn)redis服務(wù)器問(wèn)題,需要的朋友參考下吧2017-04-04

