34.Java之集合类总结(集合类的选择,Collections工具类介绍,Collections工具类常用方法)

34.1 集合类的选择

在开发中,选择什么集合实现类,主要取决于 业务操作特点,然后根据集合实现类特性进行选择

  1. 先判断存储的类型(一组对象[单列]或一组键值对[双列])
  2. 一组对象[单列]:Collection接口
  • 允许重复:List
    增删多:LinkedList(底层维护了一个双向链表)
    改查多:ArrayList(底层维护 Object 类型的可变数组)
  • 不允许重复:Set
    无序:HashSet [底层是 HashMap,维护了一个哈希表,即 数组+链表+红黑树]
    排序:TreeSet
    插入和取出顺序一致:LinkedHashSet,维护数组 + 双向链表
  1. 一组键值对[双列]:Map
  • 键无序:HashMap [底层是:哈希表,数组+链表+红黑树]
  • 键排序:TreeMap
  • 键插入和取出顺序一致:LinkedHashMap
  • 读取文件:Properties
34.2 Collections工具类
Collections 工具类介绍
  1. Collections 是一个操作 Set、List 和 Map 等集合的工具类
  2. Collections 中提供了一系列静态的方法对集合元素进行排序、查询和修改等操作
排序操作:(均为 static 方法)
  1. reverse(List):反转 List 中元素的顺序
  2. shuffle(List):对 List 集合元素进行随机排序
  3. sort(List):根据元素的自然顺序对指定 List 集合元素按升序排序
  4. sort(List,Comparator):根据指定的 Comparator 产生的顺序对 List 集合元素进行排序
List list = new ArrayList();
list.add("tom");
list.add("smith");
list.add("jack");
Collections.sort(list, new Comparator<Object>() {
    @Override
    public int compare(Object o1, Object o2) {
        return ((String)o1).length() - ((String)o2).length();
    }
});
  1. swap(List,int,int):将指定 List 集合中的 i 处元素和 j 处元素进行交换
  2. Object max/min(Collection):根据元素的自然顺序,返回给定集合中的最大(最小)元素
  3. Object max/min(Collection,Comparator):根据 Comparator 指定的顺序,返回给定集合中的最大(最小)元素
Object maxObj = Collections.max(list, new Comparator<Object>() {
	@Override
	public int compare(Object o1, Object o2) {
	    return ((String)o1).length() - ((String)o2).length();
	}
});
  1. int frequency(Collection,Object):返回指定集合中指定元素的出现次数
  2. void copy(List dest,List src):将 src 中的内容复制到 dest 中
  3. boolean replaceAll(List list,Object oldVal,Object newVal): 使用新值替换 List 对象的所有旧值
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值