谈谈JAVA并发程序设计现状和发展前景
关键字:JAVA并发程序确实到了并发盛行的时期了,我觉得最重要的原因还是多核处理器及其硬件体系的日趋成熟,并且成本摊薄到大众价格了. j.u.c包主要是为了 性能 来的,其设计其实不如 Java 传统的内置同步机制(synchronized块和方法,以及Object.wait();Object.n
关键字:JAVA并发程序确实到了并发盛行的时期了, 我觉得最重要的原因还是多核处理器及其硬件体系的日趋成熟, 并且成本摊薄到大众价格了.
j.u.c 包主要是为了
性能来的, 其设计其实不如
Java传统的内置同步机制(synchronized块和方法, 以及 Object.wait(); Object.notify())优雅, 但是传统同步机制的最大弊病就是不区分共享同步(一般是并发的读操作) 与 互斥同步 (一般是写操作), 所有同步都只能是完全排他的,只要有并发写的可能性就不得不把全部读操作也互斥同步,从而丧失并发读取的可能性. 这跟大多数应用的并发模式(读远多过于写)存在严重偏离, 以至于硬件新增长出来的并发能力在普通应用中将被大部分折扣掉, 这个是不可能被应用软件
开发市场容忍的. 同时传统同步机制也有一些灵活性方面的弊病, 比如 Object.wait(); Object.notify(); 必须在该对象的同步块内执行 (否则会抛IllegalMonitorStateException), 并且一个对象只能wait/notify一个状态. j.u.c 类通过让一个Lock可以建多个Condition去wait/notify增强了灵活性.
原文转自:http://www.ltesting.net