文章详情页
java线程为什么这样没有输出
浏览:121日期:2024-02-01 13:09:32
问题描述
List<String> list = Arrays.asList('a','b','c','d'); ExecutorService service = Executors.newFixedThreadPool(2); service.execute(() -> list.parallelStream().forEach(System.out::println));
这样一段代码什么都没输出,而将parallelStream去掉就可以输出,这是什么机制?谁能解释下
问题解答
回答1:parallelStream 方法是并发执行,相当于开启了线程在执行输出sout。没有输出的原因是主线程执行完了,子线程也就完了,此时就没有sout,在代码最后加个等待,就可以看到效果
回答2:parallel...这个方法是干什么用的?
回答3:2楼的答案非常好相当于开启了n+个线程而并不是n个
标签:
java
相关文章:
1. 关于docker下的nginx压力测试2. angular.js - angular内容过长展开收起效果3. docker - 如何修改运行中容器的配置4. java - EventBus 3.0 nullPoint异常?5. docker镜像push报错6. 为什么我ping不通我的docker容器呢???7. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题8. javascript - fis3使用MD5但是如何引用?9. javascript - Img.complete和img.onload判断图片加载完成有什么区别?10. angular.js使用$resource服务把数据存入mongodb的问题。
排行榜
