单例模式中的DCL与Volatile

    在设计模式中,有用Double check lock来处理单例的经典模式。
    但是我看了一些文章提到dcl失效的问题,主要是java2之前的版本,所以操作都是在主存储空间中执行,而对象创建操作又分为三部分:1.分配空间。2.复制对象。3.初始化对象。 这样多线程可能就会拿到尚未初始化完全的对象了。
    而在java2之后,操作会先在工作存储空间中进行,完了之后才赋值给主存储空间(引用复制)。这样就不可能造成另一线程获取未完全初始化的对象了。不过单例对象中的属性和引用还可能会存在可见性的问题,所以使用volatile来进行修复。
   
    这里我有个疑问:volatile保证可见性是将操作直接放在主存储中进行,而不是在工作内存中操作,这样不是又变回了java2之前的工作模式了吗。那怎么样保证不会出现获取尚未初始化完全的对象呢?

http://www.javamex.com/tutorials/synchronization_volatile_java_5.shtml

As of Java 5, accessing a volatile variable creates a memory barrier: it effectively synchronizes all cached copies of variables with main memory, just as entering or exiting a synchronized block that synchronizes on a given object.