您的位置:首页 > 其它

什么是CAS?什么是ABA问题?

2019-05-30 07:00 309 查看

什么是CAS?

与synchronzied修饰方法(静态代码、实例方法)、静态代码块不同的是,使用compareAndSwap()保证无锁执行线程安全。乐观锁总是认为访问共享资源的时候不会发生冲突,不用加锁不用等待可以不停的执行,如果出现冲突CAS保证线程执行的安全性

compare(V E N)方法,V表示以前记录要更新的变量的值,E表示内存中的值,N表示要更新的新的值

多个线程同时使用CAS操作一个变量的时候,如果要更新的变量的值和当前内存中的值是不一样的,表示当前变量已经被某线程执行了修改操作并刷新到了内存中,此时更新新值失败,更新失败可以重新进行更新也可以放弃更新。如果要更新的变量的值和当前的内存中的值是一样的,表示没有其他线程修改了该值 (也可能是修改了但是又重新改了过来,就是ABA问题),此时执行更新操作,多个线程只会有一个胜出并成功更新,其他的均会失败,失败的线程并不会被挂起只是被告知失败并且允许再次尝试或者放弃尝试

总结:通过CAS的方式 能够实现多个线程无锁并发执行,多个线程操作一个变量的时候只会有一个线程胜出,其他线程可以继续尝试或者放弃,CAS不会出现死锁状态

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: