parallelStream()线程安全吗?

我这边做了一个实例来验证JAVA8多线程操作parallelStream()线程安全问题

	List<Integer> integers = Lists.newArrayList();
    for (int i = 0; i < 100; i++){
        //插入100个数据
        integers.add(i);
    }
    System.out.println(integers.parallelStream().count());
	//多管道遍历
    List<Integer> integerList = Lists.newArrayList();
    integers.parallelStream().forEach(e -> {
        //添加list的方法
         integerList.add(e);
        try {
            //休眠100ms,假装执行某些任务
            Thread.sleep(100);
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
    });
    System.out.println(integerList.parallelStream().count());//97

实例中建立两个数组集合,一个赋予100个数据,另一个为空,通过parallelStream()多线程遍历方法调用 integerList 的写功能,结果发现最后integerList 只是写入97条数据,丢失的三条数据被线程“吃“掉了,所以说这种并行流还是谨慎使用。
下面是我写的一个并行流对集合操作的一个解决办法,需要并行流操作的集合创建锁集合

	List<Integer> integers = Lists.newArrayList();
    for (int i = 0; i < 100; i++){
        //插入100个数据
        integers.add(i);
    }
    System.out.println(integers.parallelStream().count());
	//多管道遍历 这边处理的时候创建锁集合
    List<Integer> integerList = Collections.synchronizedList(new ArrayList<>());
    integers.parallelStream().forEach(e -> {
        //添加list的方法
        //System.out.println("ThreadName:" + Thread.currentThread().getName());
        integerList.add(e);
        try {
            //休眠100ms,假装执行某些任务
            Thread.sleep(100);
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
    });
    System.out.println(integerList.parallelStream().count());//100

输出结果正确插入了100条数据
输出结果
验证多线程输出:
在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值