java - volatile中i++的原子性问题
本文介绍了java - volatile中i++的原子性问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
/**
* @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
解决方案
你可能需要这样:
public void run() {
for (int k = 0; k < 10000; k++)
synchronized (Main.class) {
i++;
}
}
或者定义一个AtomicInteger
volatile只是起一个多线程缓存一致性作用,并不能保证某时刻只有一个线程去写变量。
这篇关于java - volatile中i++的原子性问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文