java并发中锁可以解决线程安全的问题,但是缺点也是很明显的,当一个线程没有获取到锁时会被阻塞挂起,当锁释放后 ,又会重新调度,这种线程的上下文切换和重新调度带来了一定的性能开销。当然,java也提供了volatile关键字这种非阻塞的方法来解决共享变量在线程间的可见性问题。但是volatile虽然解决了可见性,并且也是非阻塞的,但是却不能保证原子操作。对于读-改-写(比如java的自增操作),使用volatile就会出问题。
针对于此,java提供了CAS锁机制--compare and swap。 CAS通过硬件保证了操作的原子性。
jdk中的rt.jar包中的Unsafe类提供了一系列的cas操作。
以Unsafe类中的public final native boolean compareAndSwapLong(Object obj, long valueOffset, long expect, long update)方法来举例说明cas的原理:四个参数分别是:操作对象,对象中的变量的偏移量,变量预期值,变量要更新的值。该方法功能为:如果对象obj中内存偏移量为valueOffset的变量值为expect,则将该值更新为update,并返回true,否则,返回false.
1083

被折叠的 条评论
为什么被折叠?



