三种线程安全数组(代码参考)

该代码示例对比了在多线程环境下使用synchronizedList、CopyOnWriteArrayList和Vector的性能。通过对添加操作的并发执行,测量了每种数据结构的执行时间和列表大小,以确定在不同场景下的效率最优选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、包含

1、synchronizedList

2、CopyOnWriteArrayList

3、Vector

使用时建议根据需要场景进行模拟,选择效率最优的一款。

2、代码参考

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Vector;
import java.util.concurrent.*;

/**
 * 线程安全数组list
 * @author kaura
 */
public class EzFutures {

    private static int CIRCULATE = 10000;

    public static void main(String[] args) throws ExecutionException, InterruptedException, TimeoutException {
        // 创建一个简单点线程池
        ThreadPoolExecutor executor =  new ThreadPoolExecutor(
                50,
                100,
                1000,
                TimeUnit.SECONDS,
                new ArrayBlockingQueue<>(16),
                new ThreadPoolExecutor.CallerRunsPolicy());

        List<CompletableFuture<Void>> futureList = new ArrayList<>();

        // 第一种 使用synchronizedList
        // List<Integer> list = new ArrayList<>();
        // List<Integer> syncList = Collections.synchronizedList(list);
        // 第二种,使用CopyOnWriteArrayList
        // CopyOnWriteArrayList<Integer> syncList = new CopyOnWriteArrayList<>();
        // 第三种,使用vector
        Vector<Integer> syncList = new Vector<>();
        // 开始时间
        long startTime = System.currentTimeMillis();
        for (int i = 0; i < CIRCULATE; i++) {
            CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {
                try{
                    Thread.sleep(100);
                    syncList.add(1);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }, executor);
            futureList.add(future);
        }
        CompletableFuture.allOf(futureList.toArray(new CompletableFuture[0]))
                .get(300, TimeUnit.MILLISECONDS);
        // 结束时间
        long endTime = System.currentTimeMillis();
        System.out.println("执行时间(毫秒):" + (endTime - startTime) + "ms,  syncListSize:" + syncList.size());
        // 执行时间(毫秒):51086ms,  syncListSize:10000   CopyOnWriteArrayList
        // 执行时间(毫秒):47842ms,  syncListSize:10000   synchronizedList
        // 执行时间(毫秒):47000ms,  syncListSize:10000   Vector
    }
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值