原子性

Volatile关键字

1.出现原因:
代码演示:
public class Money {
public static int money = 100000;
}

public class MyThread1 extends Thread{
@Override
public void run() {
while (Money.money == 100000){

    }
    System.out.println("结婚基金已经不是十万了");
}

}

public class MyThread2 extends Thread {
@Override
public void run() {
try {
Thread.sleep(100);
Money.money = 90000;
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

public static void main(String[] args) {
MyThread1 t1 = new MyThread1();
t1.setName(“老王”);
t1.start();

   MyThread2 t2 = new MyThread2();
   t2.setName("隔壁");
   t2.start();
}
程序问题 :**  线程1虽然知道钱是十万,但是当钱的余额发生变化的时候,线程1无法知道最新的值。

2.volatile
上边代码出现的问题:
当线程Thread2修改了共享数据时,线程Thread1没有及时获取到最新的值,如果还在使用原先的值,就会出现问题;
堆内存是唯一的,每一个线程都有自己的线程栈;
每一个线程在使用堆里面变量的时候,都会先拷贝一份到变量的副本中;
在线程中,每一次使用是从变量的副本中获取的.
Volatile关键字:强制线程每次在使用的时候,都会看一下共享区域最新的值;
代码演示:(使用volatile关键字解决)
public class Money {
public static volatile int money = 100000;
}

public class MyThread1 extends Thread{
@Override
public void run() {
while (Money.money == 100000){

    }
    System.out.println("结婚基金已经不是十万了");
}

}

public class MyThread2 extends Thread {
@Override
public void run() {
try {
Thread.sleep(100);
Money.money = 90000;
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

public static void main(String[] args) {
MyThread1 t1 = new MyThread1();
t1.setName(“老王”);
t1.start();

   MyThread2 t2 = new MyThread2();
   t2.setName("隔壁");
   t2.start();
}
  1. synchronized(锁)解决
    synchronized解决: 线程获得锁; 清空变量副本; 拷贝共享变量最新的值到变量副本中; 执行代码; 将修改后变量副本中的值赋
    值给共享数据; 释放锁.
    代码演示:
    public class Money {
    public static Object lock = new Object();
    public static int money = 100000;
    }

public class MyThread1 extends Thread{
@Override
public void run() {
while (true){
synchronized (Money.lock){
if (Money.money != 100000){
System.out.println(“结婚基金已经不是十万了”);
break;
}
}
}
}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值