java - volatile中i++的原子性问题
怪我咯
怪我咯 2017-04-18 10:52:11
0
3
638
/** * @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)
Peter_Zhu

你可能需要这样:

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

或者定义一个AtomicInteger

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

    Ty80

    volitile不保证原子性

      刘奇

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

        最新下载
        更多>
        网站特效
        网站源码
        网站素材
        前端模板
        关于我们 免责声明 Sitemap
        PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!