`

[JCIP]Chapter 1.3 多线程的风险

 
阅读更多

 Java内置的多线程是把双刃剑,一方面: 它提供了语言,库,以及跨平台的内存模型的支持,方便了用户对并发的开发。
 另一方面,它降低了多线程开发的难度,导致了开发门槛低,但多线程是个高级话题,需要额外考虑多线程问题
 1.3.1 正确性问题
 多线程在缺乏充足同步的情况下,它们的运行结果是难以预料的。在没有同步控制下,编译器,硬件,运行过程中都可以对操作进行时间和顺序的改进。 如在寄存器或处理器缓存变量。因为这样做可以提高性能,但这样会破坏安全性
 1.3.2 存活性问题
  正确性问题在单线程和多线程都会出现,只是多线程会额外引入一些正确性问题。而存活性问题是多线程独有的。
  存活性关注的是顺利达到了最终的结果。存活性问题是程序进入了一种无法通往成功的状态,就像死循环一样
  多线程会额外带来死锁,饿死,活锁等存活性问题。这些问题很难定位,因为它们依赖于特定的时间或事件 
 1.3.3 性能问题
   多线程会额外带来一些性能问题,并发设计良好的系统能够提高性能。但因为多线程本身也需要消耗一定运行时间。
   在很多线程存在情况下,线程之间的却换会非常频繁,却换需要进行上下文却换等昂贵操作。
   线程之间的同步操作会阻碍编译器优化,内存缓存失效,这些都会带来性能损失。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics