①为什么ArrayList 是线性不安全的?
②替代措施及解决方案?
ArrayList 我们都知道底层是以数组方式实现的,实现了可变大小的数组,它允许所有元素,包括null。看下面一个例子:开启多个线程操作List集合,向ArrayList中增加元素,同时去除元素。
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Vector;
public class ListTest {
// ArrayList
protected static ArrayList arrayList = new ArrayList();
// 解决措施①:使用Vector集合
protected static Vector<Object> arrayListSafe1 = new Vector<Object>();
// 解决措施②:我们加上Collections.synchronizedList,它会自动将我们的list方法进行改变,最后返回给我们一个加锁了List
static List<Object> arrayListSafe2 = Collections.synchronizedList(new ArrayList<Object>());
public static void main(String[] args) {
Thread[] threads = new Thread[500];
for (int i = 0; i < threads.length; i++) {
threads[i] =