所谓不是原子操作,意思是n++可以分解成多步操作比如这样a=n;a+=1;n=a;这里只是便于理解才写成这种形式,要较真的话,其实a+=1的操作是在CPU里,而前后两步是在内存里,并不是代码真的长这样那么当多线程同时执行这个操作的时候,线程1里的a获取到n的值是1,线程2获取到的也是1(因为线程1还没有执行完,没有把n的值写回去)那么线程1和线程2分别执行a+=1的操作之后,先后给n赋值2,n赋值了2次2