java - volatile中i++的原子性问题
问题描述
/** * @create on 17/3/27 * @description */public class Main { static volatile int i = 0; public static class PlusTask implements Runnable{@Overridepublic 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
问题解答
回答1:你可能需要这样:
public void run() { for (int k = 0; k < 10000; k++)synchronized (Main.class) { i++;}}
或者定义一个AtomicInteger
volatile只是起一个多线程缓存一致性作用,并不能保证某时刻只有一个线程去写变量。
回答2:volitile不保证原子性
回答3:多线程操作共享变量问题,volitale不能不保证复合操作的原子性,也就是说后一个线程并不能总是看到前一个线程修改后的值i,解决方法加锁,或者原子操作
相关文章:
1. 如何解决docker宿主机无法访问容器中的服务?2. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????3. javascript - 请指条明路,angular的$event,在select中却是undefined?4. 如何修改vim插件vimwiki中Vimwiki2HTML的一些细节5. javascript - JS事件委托问题6. javascript - 关于jquery的remove()方法7. JavaScript中怎么理解=、==和===8. java - Spring事务回滚问题9. javascript - vue.js如何递归渲染组件.10. mongodb - Mongo java驱动中,有没有封装好的函数,可以直接取到文档中的某个具体的值,而不是一个文档?或者有没有方法实现??
