java多线程中的原子操作


线程原子操作

(PS:记录学习轨迹,如有问题,请拍砖:)

一 概念
二 常见情况
三 实例:序列号问题
四 建议:安全操作
五 参考资料



一 概念

  (automic operation)即不能被线程调度机制中断的操作。原子操作不需要进行同步控制。

二 常见情况

  如果问题中的变量除了long or double 以后的基本类型,对这些类型进行简单的赋值或者返回操作时是原子操作。为类型long and double 加上volatile修饰符,对这两个基本类型的操作也是原子的。
  JVM中自增或减并不是原子操作,i++ or i-- 因为其中涉及一次读和写,在执行过程中可能被修改。
 
三 实例:序列号问题
   每个线程都可能在本地拥有一个本地的栈以维护一些变量的复本。如果把一个变量变成volatile,就等于告诉编译器不要做任何优化,这些优化可能会移除那些字段与线程里的本地复本保持同步的读写操作。 

uml,源码在附件

四 原子操作只有对基本类型进行读取或赋值操作时才会被认为是安全的。
   最安全的两个方针:
       1 如果你要对类的某个方法进行同步,那么最好同步所有 的方法。
       2 去除方法的同步控制时,要十分小心。通常这么做是因为性能的有瓶颈时,最好利 用性能评价工具证实。


五 参考资料:
《Thinking in java》 author:Bruce Eckel
         基本线程--共享受限资源--解决共享资源竞争--原子操作
volatile: http://baike.baidu.com/view/608706.htm
           http://galaxystar.iteye.com/blog/109150
           内存模型 http://blog.csdn.net/silentbalanceyh/    archive/2009/10/13/4661230.aspx

你可能感兴趣的:(java,jvm,多线程,Blog,UML)