sosxu110 2016-11-10 06:34 采纳率: 60%
浏览 1211
已采纳

java线程停止whlie里面的if语句,一会可以执行,一会不可以执行

我将if条件的times设置成大于等于二,但是一般要多执行几次才会执行出show,经常不会执行show,这是怎么回事啊?
public class TestBank {

public static void main(String[] args) {
    new TestBank().run();
}

public void run() {
    Family f = new Family();
    new Thread(f,"丈夫").start();
    new Thread(f,"妻子").start();
    while(true){
        if(f.times>=2) {
            f.show();
            break;
        }
    }
}
class Family implements Runnable {
    private int saveMoney;
    private int getMoney;
    private int curMoney;
    private volatile int times = 0;

    public Family() {
        saveMoney = 5000;
        getMoney = 2000;
        curMoney = 0;
    }
    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName()+"取了:"+getMoney+"元");
            curMoney+=getMoney;
            int temp = saveMoney - getMoney;
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            saveMoney = temp;
            times++;
    }


    public void show() {
        System.out.println("银行还有:"+saveMoney+",家里中有:"+curMoney);
    }
}

}

  • 写回答

1条回答 默认 最新

  • little_how 2016-11-10 07:01
    关注

    你的times++线程不安全啊,有可能最终的执行结果为times=1;
    这里你可以选择使用AtomicInteger(在包java.util.concurrent.atomic下)
    如: private AtomicInteger times = new AtomicInteger(0);
    times++;改成times.incrementAndGet();
    判断那里改成f.times.get()>=2
    atomic包下的这些都是原子性操作的

    希望可以帮到你...

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 求数据集和代码#有偿答复
  • ¥15 关于下拉菜单选项关联的问题
  • ¥15 如何修改pca中的feature函数
  • ¥20 java-OJ-健康体检
  • ¥15 rs485的上拉下拉,不会对a-b<-200mv有影响吗,就是接受时,对判断逻辑0有影响吗
  • ¥15 使用phpstudy在云服务器上搭建个人网站
  • ¥15 应该如何判断含间隙的曲柄摇杆机构,轴与轴承是否发生了碰撞?
  • ¥15 vue3+express部署到nginx
  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况