Java 原子操作的实现

    Java 原子操作分为处理器实现和 Java 程序实现。

处理器实现:
    处理器使用基于对缓存加锁或总线加锁的方式实现多处理器之间的原子操作。
    (1)第一个机制是使用总线锁保证原子性。
    如果多个处理器同时对共享变量进行读改写操作(例如,i++ 就是经典的读改写操作),这样读改写操作就不是原子的。如果想要保证读改写共享变量的操作是原子的,就必须保证 CPU1 读改写共享变量的时候,CPU2 不能操作缓存了该变量内存地址的缓存。处理器使用总线锁解决这个问题。所谓总线锁就是使用处理器提供的一个 LOCK# 信号,当一个处理器在总线上输出此信号时,其他处理器的请求将被阻塞,那么该处理器可以独占共享内存。
    (2)第二个机制是通过缓存锁定来保证原子性。
    在同一时刻,我们只需要保证对某个内存地址的操作是原子性即可。但总线锁开销比大。所谓“缓存锁定”是指内存区域如果被缓存在处理器的缓存行中,并且在 Lock 操作期间被锁定,那么当它执行锁操作回写到内存时,处理器不在总线上声言 LOCK# 信号,而是修改内部的内存地址,并允许它的缓存一致性机制来保证操作的原子性,因为缓存一致性机制会阻止同时修改由两个以上处理器缓存的内存区域数据。

Java 实现原子操作:
    在 Java 中可以通过锁和循环 CAS 的方式来实现原子操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值