TeslaHua 2016-03-11 11:28 采纳率: 0%
浏览 1417

关于java 中的线程同步问题,求大神解释。

对于一个已经继承了Runnable 接口的类来说,假设创建了一个它的实例为 account,
那么:
for(int i=0;i<500;i++)
{
new Thread(account).start();

}
不会造成500个线程同步访问同一资源而引发冲突?

为什么:
                        private ExecutorService executor = Executors.newCachedThreadPool();                //在线程池中为每个等待的任务创建一个线程
                        for(int i=0;i<500;i++)
                        {
                                        executor.execute(account);  
                        }
                        这样就会造成线程同步访问同一临界资源冲突呢?
  • 写回答

1条回答 默认 最新

  • TeslaHua 2016-03-11 11:47
    关注

    或者说,其实都能产生线程同步访问同一临界资源冲突的情况,只不过后者可以在临界资源程序块 加上 synchronized 关键字,使其变成线程安全的;
    而前者加上也不起作用呢?

    评论

报告相同问题?

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题