为了账号安全,请及时绑定邮箱和手机立即绑定

volatile中i++的原子性问题

volatile中i++的原子性问题

长风秋雁 2019-03-01 11:16:47
/** * @create on 17/3/27 * @description */ public class Main { static volatile int i = 0; public static class PlusTask implements Runnable{ @Override public void run(){ for(int k=0; k<10000; k++) i++; } } public static void main(String[] args) throws InterruptedException{ Thread[] threads = new Thread[10]; for(int i=0;i<10;i++){ threads[i] = new Thread(new PlusTask()); threads[i].start(); } for(int i=0;i<10;i++){ threads[i].join(); } System.out.println(i); } } 请教各位大牛 为什么这里的输出总是小于10000? 已经调用了thread.join
查看完整描述

3 回答

?
一只名叫tom的猫

TA贡献1906条经验 获得超3个赞

你可能需要这样:

public void run() {
            for (int k = 0; k < 10000; k++)
                synchronized (Main.class) {
                    i++;
                }
        }

或者定义一个AtomicInteger

  • volatile只是起一个多线程缓存一致性作用,并不能保证某时刻只有一个线程去写变量。

查看完整回答
反对 回复 2019-03-01
?
芜湖不芜

TA贡献1796条经验 获得超7个赞

volitile不保证原子性

查看完整回答
反对 回复 2019-03-01
?
泛舟湖上清波郎朗

TA贡献1818条经验 获得超3个赞

多线程操作共享变量问题,volitale不能不保证复合操作的原子性,也就是说后一个线程并不能总是看到前一个线程修改后的值i,解决方法加锁,或者原子操作

查看完整回答
反对 回复 2019-03-01
  • 3 回答
  • 0 关注
  • 1147 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号