java Collections工具类

数组中的有Arrays工具类,可以对数组操作,见我的博客 https://mp.csdn.net/postedit/83933998

集合框架中也有跟工具类Collections,下面主要介绍其中的常用方法

基础方法:

 max(Collection<? extends T> coll)  返回集合中最大的元素,此元素类必须实现Comparable接口,并重写compareTo方法

static void reverse(List<?> list)     对给定List进行翻转

static void shuffle(List<?> list)  打乱List中的元素在List中的位置,洗牌

 void sort(List<T> list) 对给定List的元素进行升序排序(自然排序),元素类必须实现Comparable接口,重写compareTo方法

static <T> int binarySearch(List<? extends Comparable<? super T>> list, T key)   对List中的元素进行二分查找,返回索引值,如无此元素,返回-1,List要先排好序,且元素类必须实现Comparable接口,重写compareTo方法

static void swap(List<?> list, int i, int j)      List中索引i处与索引j处的元素交换位置

replaceAll(List list, Object old, Object new):替换

同步方法:

 <T> Collection<T> synchronizedCollection(Collection<T> c) 根据给定集合返回一个线程安全的集合

 <T> List<T> synchronizedList(List<T> list)   根据给定List返回一个线程安全的List

 <K,V> Map<K,V> synchronizedMap(Map<K,V> m)   根据给定Map返回一个线程安全的Map

<K,V> SortedMap<K,V> synchronizedSortedMap(SortedMap<K,V> m) 根据给定SortedMap返回一个线程安全的SortedMap

 <T> Set<T> synchronizedSet(Set<T> s)   根据给定Set返回一个线程安全的Set
 
<T> SortedSet<T> synchronizedSortedSet(SortedSet<T> s)   根据给定SortedSet返回一个线程安全的SortedSet

 常用方法示例:

import java.util.ArrayList;
import java.util.Collections;

public class CollectionsTest01 {
	public static void main(String[] args) {
		ArrayList<Integer> list = new ArrayList<>();
		list.add(2);
		list.add(1);
		list.add(4);
		list.add(3);
		list.add(0);
		// 根据给定集合获取最大值
		System.out.println(Collections.max(list));// 4
		// 反转集合
		Collections.reverse(list);
		System.out.println(list);// [0, 3, 4, 1, 2]

		// 随机打乱集合中元素的顺序
		Collections.shuffle(list);
		System.out.println(list);
		// 多集合中的元素进行排序
		Collections.sort(list);
		System.out.println(list);// [0, 1, 2, 3, 4]
		// 二分查找集合中的元素,
		System.out.println(Collections.binarySearch(list, 3));// 3
		System.out.println(Collections.binarySearch(list, 15));// -6,对于没有的元素,查找返回不正确的值

	}
}
out:
4
[0, 3, 4, 1, 2]
[2, 0, 3, 1, 4]
[0, 1, 2, 3, 4]
3
-6

 

参考:http://www.monkey1024.com/javase/588

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值