老生常谈…对于大佬们根本都不用看的博客!
对于像我这种菜鸡还是得一步一步的来!如果有错误请大佬们指点指点!
volatile
简介
当线程 A 修改了共享数据的时候,B 线程没有及时获取到最新的数据,如果还在使用原先的数据,就会出现问题。 这该怎么办呢?
然后volatile 关键字就会强制线程在每次使用的时候,都会看一下共享区域最新的数据。
当然也可以用synchronized的方法(例如火车票问题),我们今天介绍的时volatile ,废话不多说直接上代码:
public class TestVolatile {
static class Money {
public static volatile int money = 10;
}
static class Me extends Thread{
@Override
public void run() {
while (Money.money == 10){
System.out.println("我还有十块钱!");
}
System.out.println("我的钱没了!");
}
}
static class You extends Thread{
@Override
public void run() {
try {
Thread.sleep(50);
} catch (InterruptedException e) {
e.printStackTrace();
}
Money.money = 0;
System.out.println("借点钱!");
}
}
public static void main(String[] args) {
Me me = new Me();
You you = new You();
me.start();
you.start();
}
}
原子性
简介
原子性指的是一次操作或多次操作,要么所有的操作都会成功,要么所有的操作都不成功。
volatile 关键字只能保证每次使用共享数据的时候是最新值,但是不能保证原子性。
atomic类能够保证原子性。
synchronized 和 CAS 的区别
- 相同点:在多线程的情况下,都可以保证共享数据的安全性。
- 不同点:synchronized是悲观锁,CAS是乐观锁。