Collection 和 Collections 的区别与用法
- 1、Collection 接口
- 1.1 主要特点
- 1.2 常见方法
- 2、 Collections 工具类
- 2.1 主要特点
- 2.2 常见方法
- 3、示例代码
- 3.1 使用 Collection 接口
- 3.2 使用 Collections 工具类
- 4、总结
💖The Begin💖点点关注,收藏不迷路💖 |
在Java中,Collection
和 Collections
是两个非常重要的概念,但它们的功能和用途截然不同。尽管它们的名字相似,但它们的角色和用法却大相径庭。下面,我们将详细探讨这两个概念的区别和用法。
1、Collection 接口
Collection
是Java集合框架中的一个根接口。它定义了所有集合都应该有的基本操作,如添加、删除、检查元素是否存在等。Collection
接口并不直接用于实例化对象,而是由其子接口(如 List
、Set
和 Queue
)或实现类(如 ArrayList
、LinkedList
、HashSet
、TreeSet
等)来实现具体的集合功能。
1.1 主要特点
- 提供了集合的基本操作,如添加、删除、检查元素是否存在等。
- 不提供元素的顺序保证(除了
List
和它的实现类,如ArrayList
和LinkedList
)。 - 允许元素重复(除了
Set
和它的实现类,如HashSet
和TreeSet
)。
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💖点点关注,收藏不迷路💖 |