Collection 和 Collections 的区别与用法


💖The Begin💖点点关注,收藏不迷路💖

在Java中,CollectionCollections 是两个非常重要的概念,但它们的功能和用途截然不同。尽管它们的名字相似,但它们的角色和用法却大相径庭。下面,我们将详细探讨这两个概念的区别和用法。

1、Collection 接口

Collection 是Java集合框架中的一个根接口。它定义了所有集合都应该有的基本操作,如添加、删除、检查元素是否存在等。Collection 接口并不直接用于实例化对象,而是由其子接口(如 ListSetQueue)或实现类(如 ArrayListLinkedListHashSetTreeSet 等)来实现具体的集合功能。

1.1 主要特点

  • 提供了集合的基本操作,如添加、删除、检查元素是否存在等。
  • 不提供元素的顺序保证(除了 List 和它的实现类,如 ArrayListLinkedList)。
  • 允许元素重复(除了 Set 和它的实现类,如 HashSetTreeSet)。

1.2 常见方法

  • boolean add(E e): 添加元素到集合中。
  • boolean remove(Object o): 从集合中移除指定元素。
  • boolean contains(Object o): 检查集合中是否包含指定元素。
  • int size(): 返回集合中元素的数量。
  • Iterator<E> iterator(): 返回此集合的迭代器。

2、 Collections 工具类

Collections 是Java提供的一个工具类,它包含了对集合进行操作的静态方法。这些方法可以对集合进行搜索、排序、线程安全化等操作,而无需修改集合的源代码。

2.1 主要特点

  • 提供了一系列静态方法,用于对集合进行搜索、排序、线程安全化等操作。
  • 不能直接实例化,只能使用其中的静态方法。

2.2 常见方法

  • sort(List<T> list): 对列表进行自然排序。
  • sort(List<T> list, Comparator<? super T> c): 根据指定的比较器对列表进行排序。
  • binarySearch(List<? extends Comparable<? super T>> list, T key): 使用二分查找算法在已排序的列表中搜索指定元素。
  • max(Collection<? extends T> coll): 返回集合中的最大值元素(根据元素的自然顺序或比较器)。
  • synchronizedList(List<T> list): 返回指定列表支持的同步(线程安全)列表。

3、示例代码

3.1 使用 Collection 接口

List<String> list = new ArrayList<>();  
	list.add("Apple");  
	list.add("Banana");  
	list.add("Cherry");  
System.out.println(list.contains("Banana")); // 输出: true

3.2 使用 Collections 工具类

List<String> list = new ArrayList<>();  
	list.add("Apple");  
	list.add("Banana");  
	list.add("Cherry");  
  
	Collections.sort(list); // 对列表进行自然排序  
System.out.println(list); // 输出: [Apple, Banana, Cherry]  
  
int index = Collections.binarySearch(list, "Banana"); // 使用二分查找算法搜索元素  
System.out.println(index); // 输出: 1

4、总结

1、Collection 是Java集合框架中的一个根接口,它定义了集合的基本操作,并由其子接口和实现类来实现具体的集合功能。

2、而 Collections 是一个工具类,它提供了一系列静态方法,用于对集合进行搜索、排序、线程安全化等操作,而无需修改集合的源代码。

在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖
  • 28
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Seal^_^

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值