栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

CAS与synchronized

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

CAS与synchronized

synchronized
代表的是一种阻塞式的锁,得不到锁会进入阻塞队列,等待线程进行唤醒,有上下文切换的开销。
原子变量是非阻塞式的,有冲突一直循环重试。

public final int incrementAndGet() {
	for(;;) {
	int current = get();
	int next = current + 1;
	if(compareAndSet(current, next))
	return next;
	}
}

基于CAS可以实现乐观非阻塞式算法,还可以悲观阻塞式算法

public class MyLock {
private AtomicInteger status = new AtomicInteger(0);
public void lock() {
while(!status.compareAndSet(0, 1)) {
Thread.yield();
}
}
public void unlock() {
status.compareAndSet(1, 0);
}
}

cas 如何解决ABA问题
使用AtomicStampedReference在修改时候同时设置时间戳,值时间戳相同才做相应修改

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/682631.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号