谁能解释为什么它在这里不起作用?由于我被声明为volatile,因此应该保护它免受内存不一致的影响。
它受到保护,但不幸的
i++是不是原子操作。它实际上是读取/递增/存储。因此,
volatile这不会使您摆脱线程之间的竞争状况。您可能会从程序中获得以下操作顺序:
- 线程#1读取
i
,得到10 - 之后,线程#2读取
i
,得到10 - #1线程
i
增加到11 - 线程#2递增
i
到11 - 线程#1将11存储到
i
- 线程2将11存储到
i
如您所见,即使发生了2个增量,并且线程之间的值已正确同步,竞争条件也意味着该值仅增加了1。请看此美观的说明。这是另一个很好的答案:Java线程中的volatileint是安全的吗?
您应该使用的是
AtomicInteger允许您从多个线程安全地递增的内容。
static final AtomicInteger i = new AtomicInteger(0);... for (int j = 0; j<1000000; j++) { i.incrementAndGet(); }


