并发锁机制

JDK1.6 synchronized (底层是由C++实现的):


synchronized: 互斥锁,悲观 锁,同步锁,重量级锁(耗性能),多线程使用重量级锁很容易发生线程阻塞,因为涉及到多个线程的启动和运行;

在线程执行具体某个方法时,其他会通过synchronized实现机制丢到任务队列,等执行线程释放锁,其他线程根据抢占获得锁,在抢占的过程中,根据上下文的切换操作系统的的调度,就会发生线程的阻塞

说明一点:JDK1.6就开始对synchronized 做了大量的优化。


通过实践对比(原子类和synchronized的性能)


原子类比synchronized锁 n++ 自增的效率更快。

原子类的底层实现是不断通过while循环进行cas,直到value设置成功,在while的这一步可能会发生死循环。


CAS(compareAndset,compareAndSwapInt),自选会成为CAS的瓶颈


cas:无锁,自旋锁,乐观锁,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

、小H

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值