Collection
Collection是Set List Queue和Deque的接口,且和Map没有关系
Collections
- Collections是一个类,容器的工具类,如同Array是数组的工具类一样。
- Collections中有许多方法,可以对容器进行操作
反转reverse
混淆shuffle
排序sort
交换swap
滚动rotate
线程安全化synchronizedList
实例:
package List;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
/**
* Collections工具类的使用
*
* @author Aike
* @create 2021-05-13 20:05
*/
public class TestCollection {
public static void main(String[] args) {
List<Integer> numbers = new ArrayList<>();
for (int i = 0; i < 10; i++) {
numbers.add(i);
}
// 反转reverse
Collections.reverse(numbers);
System.out.println(numbers);
// 混淆shuffle
Collections.shuffle(numbers);
System.out.println(numbers);
// 排序sort
Collections.sort(numbers);
System.out.println(numbers);
// 交换swap
Collections.swap(numbers, 0, 1);
System.out.println(numbers);
// 滚动rotate
Collections.rotate(numbers, 2);
System.out.println(numbers);
// 线程安全化synchronizedList
System.out.println("把非线程安全的List转换为线程安全的List");
List<Integer> synchronizedNumbers = (List<Integer>) Collections.synchronizedList(numbers);
// 练习-统计概率
// 首先初始化一个List,长度是10,值是0-9。
// 然后不断的shuffle,直到前3位出现
// 3 1 4
//
// shuffle 1000,000 次,统计出现的概率
List<Integer> array = new ArrayList<>();
float num = 0;
for (int i = 0; i < 10; i++) {
array.add(i);
}
for (int i = 0; i < 1000000; i++) {
Collections.shuffle(array);
if (array.get(0) == 3 && array.get(1) == 1 && array.get(2) == 4) {
num++;
}
}
System.out.println(num/1000000);
}
}
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
[8, 0, 9, 6, 2, 1, 7, 5, 3, 4]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[1, 0, 2, 3, 4, 5, 6, 7, 8, 9]
[8, 9, 1, 0, 2, 3, 4, 5, 6, 7]
把非线程安全的List转换为线程安全的List
0.001343