热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java集合工具类_Java集合中Collections工具类总结

Collections工具类Collections是一个操作Collection(Set、List)和Map等集合的工具类Collection和Collections的区别

Collections工具类

Collections 是一个操作 Collection(Set、 List )和 Map 等集合的工具类

Collection和Collections的区别?

Collection是用来存储单列数据的集合接口,常用子接口有List和Set

Collections是操作Collection的工具类。

常用方法

排序操作:

reverse(List): 反转 List 中元素的顺序

shuffle(List): 对 List 集合元素进行随机排序

sort(List): 根据元素的自然顺序对指定 List 集合元素按升序排序

sort(List, Comparator): 根据指定的 Comparator 产生的顺序对 List 集合元素进行排序

swap(List, int, int): 将指定 list 集合中的 i 处元素和 j 处元素进行交换

查找和替换:

Object max(Collection): 根据元素的自然顺序,返回给定集合中的最大元素

Object max(Collection, Comparator): 根据 Comparator 指定的顺序,返回给定集合中的最大元素

Object min(Collection)

Object min(Collection, Comparator)

int frequency(Collection, Object): 返回指定集合中指定元素的出现次数

void copy(List dest,List src):将src中的内容复制到dest中

boolean replaceAll(List list, Object oldVal, Object newVal): 使用新值替换List 对象的所有旧值

举例:

reverse反转方法

@Test

public void test3() {

// 测试reverse方法

List list = new ArrayList();

list.add(2121);

list.add(-1);

list.add(21);

list.add(0);

list.add(45);

//反转

Collections.reverse(list);

System.out.println(list);//[45, 0, 21, -1, 2121]

}

sort方法

@Test

public void test2() {

// 测试sort方法

List list = new ArrayList();

list.add(2121);

list.add(-1);

list.add(21);

list.add(0);

list.add(45);

//按升序排序

Collections.sort(list);

System.out.println(list);//[-1, 0, 21, 45, 2121]

}

逆序排序

int compareTo(T t)方法说明

定义:比较此对象与指定对象的顺序

返回:负整数、零或正整数。如果该对象小于、等于或大于指定对象,则分别返回负整数、零或正整数。

@Test

public void test1() {

// 测试sort方法

List list = new ArrayList();

list.add(2121);

list.add(-1);

list.add(21);

list.add(0);

list.add(45);

// 降序

Collections.sort(list, new Comparator() {

@Override

public int compare(Integer o1, Integer o2) {

System.out.println(o2 - o1);

return o2 - o1; // 此时o2-o1是大于0的

}

});

System.out.println(list);//[-1, 0, 21, 45, 2121]

}

对自定义对象的排序

方法一:通过实现Comprable的compareTo方法进行排序

// 实现Comparable接口

class User implements Comparable {

private String name;

private Integer age;

public User(String name, Integer age) {

this.name = name;

this.age = age;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

@Override

public int compareTo(User o) {

//首先比较年龄,如果年龄相同,则比较名字

int flag = this.getAge().compareTo(o.getAge());

if (flag == 0) {

return this.getName().compareTo(o.getName());

} else {

return flag;

}

}

@Override

public String toString() {

return "User{" +

"name='" + name + '\'' +

", age=" + age +

'}';

}

测试方法

// 自定义对象的排序,比如对User对象按照年龄排序,再按照name排序

@Test

public void testSort() {

User f1 = new User("tony", 19);

User f2 = new User("jack", 16);

User f3 = new User("tom", 80);

User f4 = new User("jbson", 44);

User f5 = new User("jason", 44);

User f6 = new User("tom", 12);

List list = new ArrayList();

list.add(f1);

list.add(f3);

list.add(f4);

list.add(f2);

list.add(f5);

list.add(f6);

Collections.sort(list);

for (User o : list) {

System.out.println(o.getAge() + "-->" + o.getName());

}

}

输出:

12-->tom

16-->jack

19-->tony

44-->jason

44-->jbson

80-->tom

copy方法

List dest = Arrays.asList(new Object[list.size()]);

@Test

public void testCopy(){

List list = new ArrayList();

list.add(2121);

list.add(-1);

list.add(21);

list.add(0);

list.add(45);

//错误写法:此时dest集合为长度为0,报错IndexOutOfBoundsException: Source does not fit in dest

// List dest = new ArrayList();

// Collections.copy(dest,list);

// System.out.println(dest.size());

// System.out.println(dest);

// 正确写法:先造一个值为null,长度为list长度的集合。再拷贝

List dest = Arrays.asList(new Object[list.size()]);

System.out.println(dest.size()); // 5

Collections.copy(dest,list);

System.out.println(dest);

}



推荐阅读
  • 本文详细介绍了如何利用 Bootstrap Table 实现数据展示与操作,包括数据加载、表格配置及前后端交互等关键步骤。 ... [详细]
  • 本文详细介绍了 `org.apache.tinkerpop.gremlin.structure.VertexProperty` 类中的 `key()` 方法,并提供了多个实际应用的代码示例。通过这些示例,读者可以更好地理解该方法在图数据库操作中的具体用途。 ... [详细]
  • 本文深入探讨了WPF框架下的数据验证机制,包括内置验证规则的使用、自定义验证规则的实现方法、错误信息的有效展示策略以及验证时机的选择,旨在帮助开发者构建更加健壮和用户友好的应用程序。 ... [详细]
  • td{border:1pxsolid#808080;}参考:和FMX相关的类(表)TFmxObjectIFreeNotification ... [详细]
  • 长期从事ABAP开发工作的专业人士,在面对行业新趋势时,往往需要重新审视自己的发展方向。本文探讨了几位资深专家对ABAP未来走向的看法,以及开发者应如何调整技能以适应新的技术环境。 ... [详细]
  • 本文深入探讨了Go语言中的接口型函数,通过实例分析其灵活性和强大功能,帮助开发者更好地理解和运用这一特性。 ... [详细]
  • 本文介绍了如何通过C#语言调用动态链接库(DLL)中的函数来实现IC卡的基本操作,包括初始化设备、设置密码模式、获取设备状态等,并详细展示了将TextBox中的数据写入IC卡的具体实现方法。 ... [详细]
  • 本文探讨了如何通过Service Locator模式来简化和优化在B/S架构中的服务命名访问,特别是对于需要频繁访问的服务,如JNDI和XMLNS。该模式通过缓存机制减少了重复查找的成本,并提供了对多种服务的统一访问接口。 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • 字符串中特定模式出现次数的计算方法
    本文详细探讨了如何高效地计算字符串中特定模式(如'pat')的出现次数,通过实例分析与算法解析,帮助读者掌握解决此类问题的方法。 ... [详细]
  • Java中如何判断一个对象是否为Long类型
    本文介绍了一种在Java中判断对象是否属于Long类型的方法,通过定义一个特定的方法来实现这一功能,该方法能够准确地识别并返回结果。 ... [详细]
  • 入门指南:使用FastRPC技术连接Qualcomm Hexagon DSP
    本文旨在为初学者提供关于如何使用FastRPC技术连接Qualcomm Hexagon DSP的基础知识。FastRPC技术允许开发者在本地客户端实现远程调用,从而简化Hexagon DSP的开发和调试过程。 ... [详细]
  • 本文将从基础概念入手,详细探讨SpringMVC框架中DispatcherServlet如何通过HandlerMapping进行请求分发,以及其背后的源码实现细节。 ... [详细]
  • 本文介绍了如何正确配置Ajax POST请求,以确保前端发送的数据能够被后端正确解析。重点在于前端JSON对象的键名需要与后端实体类的字段名严格匹配。 ... [详细]
  • 高级缩放示例.就像谷歌地图一样.它仅缩放图块,但不缩放整个图像.因此,缩放的瓷砖占据了恒定的记忆,并且不会为大型缩放图像调整大小的图像.对于简化的缩放示例lookhere.在Win ... [详细]
author-avatar
cathy李lee
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有