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 Jenkins+k8s部署slave节点offline
  • ¥15 微信小游戏反编译后,出现找不到分包的情况
  • ¥15 如何实现从tello无人机上获取实时传输的视频流,然后将获取的视频通过yolov5进行检测
  • ¥15 WPF使用Canvas绘制矢量图问题
  • ¥15 用三极管设计一个单管共射放大电路
  • ¥15 孟德尔随机化r语言运行问题
  • ¥15 pyinstaller编译的时候出现No module named 'imp'
  • ¥15 nirs_kit中打码怎么看(打码文件是csv格式)
  • ¥15 怎么把多于硬盘空间放到根目录下
  • ¥15 Matlab问题解答有两个问题