首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

[JCIP]Chapter 1.3 多线程的危险

2012-10-24 
[JCIP]Chapter 1.3 多线程的风险?Java内置的多线程是把双刃剑,一方面: 它提供了语言,库,以及跨平台的内存

[JCIP]Chapter 1.3 多线程的风险

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

热点排行