不满足原子性、可见性以及有序性。
1.原子性
即一个操作或者多个操作,要么全部执行并且执行的过程不会被任何因素打断,要么就都不执行。
我们把一段代码想象成一个房间,每个线程就是要进入这个房间的人。如果没有任何机制保证,A进入房间之后,还
没有出来;B 是不是也可以进入房间,打断 A 在房间里的隐私。这个就是不具备原子性的。
那我们应该如何解决这个问题呢?
只要给房间加一把锁,A 进去就把门锁上,其他人是不是就进不来了。这样就保证了这段代码的原子性了。
有时也把这个现象叫做同步互斥,表示操作是互相排斥的。
举个例子:
i = 0; //1
j = i ; //2
i++; //3
i = j + 1; //4
这4个操作中只有第一个是原子性操作。其余均不是。
操作1在Java中,对基本数据类型的变量赋值操作都是原子性的;
操作2中包含了2个操作:1.读取i;2.将i值赋给j
操作3包含了3个操作:1.读取i值;2.i+1;3.将i+的值赋给i
操作4与操作3类似
在单线程环境下我们可以认为整个步骤都是原子性操作,但在多线程环境下则不同,Java只保证了基本数据类型的变量和赋值操作才是原子性的(注:在32位的JDK环境下,对64位数据的读取不是原子性操作*,如long、double)。
不保证原子性会给多线程带来什么问题:
如果一个线程正在对一个变量操作,中