线程安全问题之原子性
1.原子操作是针对访问共享变量的操作而言的。涉及局部变量访问的操作无所谓是否原子的。
2.原子操作是从该操作的执行线程以外的线程来描述的,也就是说它只有在多线程环境下才有意义。
原子操作得“不可分割”包括两层含义
1.访问(读、写)某个共享变量的操作从其执行线程以外的任何线程来看,该操作要么已经执行结束要么尚未发生,
即其他线程不会“看到”该操作执行了部分的中间效果。
2.访问同一组共享变量的原子操作是不能够被交错的。
java实现原子性有两种方式:
1.使用锁。
1.原子操作是针对访问共享变量的操作而言的。涉及局部变量访问的操作无所谓是否原子的。
2.原子操作是从该操作的执行线程以外的线程来描述的,也就是说它只有在多线程环境下才有意义。
原子操作得“不可分割”包括两层含义
1.访问(读、写)某个共享变量的操作从其执行线程以外的任何线程来看,该操作要么已经执行结束要么尚未发生,
即其他线程不会“看到”该操作执行了部分的中间效果。
2.访问同一组共享变量的原子操作是不能够被交错的。
java实现原子性有两种方式:
1.使用锁。
2利用处理器提供的专门CAS指令
在java语言中,long/double除外的任何类型的变量的写操作都为原子操作,是由JSL规定的,由java虚拟机具体实现。
对于volatile关键字修饰的long/double型变量的写操作具有原子性(volatile long sum)。
java语言中针对任何变量的读操作都是原子操作。
原子操作+原子操作!=原子操作
所以使一个操作具有原子性就可以消除该操作导致竞态的可能性(竞态模式:read-modify-write和check-then-act)。