package singleton;
public class Singleton {
/**
* volatile这个关键字,用在多线程,同步变量
* 线程为了提高效率,将某成员变量(如A)拷贝了一份(如B),线程中对A的访问其实访问的是B。
* 只在某些动作时才进行A和B的同步。因此存在A和B不一致的情况。volatile就是用来避免这种情况的。 volatile告诉jvm,
* 它所修饰的变量不保留拷贝,直接访问主内存中的(也就是上面说的A)
*/
private volatile static Singleton uniquesingleton;
/**
* 完美的线程安全单例实例
* @return
*/
public static Singleton getSingleton() {
if (uniquesingleton == null) {
synchronized (Singleton.class) {
if (uniquesingleton == null)
uniquesingleton = new Singleton();
}
}
return uniquesingleton;
}
/**
*私有的构造方法 避免new对象
*/
private Singleton() {
}
public void getValue() {
System.out.println("这是一个单例模式的演示");
}
public static void main(String arges[]){
Singleton sing = Singleton.getSingleton();
sing.getValue();
}
}
public class Singleton {
/**
* volatile这个关键字,用在多线程,同步变量
* 线程为了提高效率,将某成员变量(如A)拷贝了一份(如B),线程中对A的访问其实访问的是B。
* 只在某些动作时才进行A和B的同步。因此存在A和B不一致的情况。volatile就是用来避免这种情况的。 volatile告诉jvm,
* 它所修饰的变量不保留拷贝,直接访问主内存中的(也就是上面说的A)
*/
private volatile static Singleton uniquesingleton;
/**
* 完美的线程安全单例实例
* @return
*/
public static Singleton getSingleton() {
if (uniquesingleton == null) {
synchronized (Singleton.class) {
if (uniquesingleton == null)
uniquesingleton = new Singleton();
}
}
return uniquesingleton;
}
/**
*私有的构造方法 避免new对象
*/
private Singleton() {
}
public void getValue() {
System.out.println("这是一个单例模式的演示");
}
public static void main(String arges[]){
Singleton sing = Singleton.getSingleton();
sing.getValue();
}
}
本文介绍了一种使用volatile关键字及双重检查锁定模式来实现线程安全的Java单例模式的方法。这种方法通过确保实例创建过程的原子性来避免多线程环境下的并发问题,并详细展示了其实现代码。
1499

被折叠的 条评论
为什么被折叠?



