单例模式的懒汉饿汉区别就是是否在程序一开始就创建单例
- 懒汉:很懒,所以一开始不创建单例,等到需要用到的时候才创建单例,用时间换空间。
注意:懒汉单例是线程不安全的,如果有两个线程,我们称它们为线程1和线程2,在同一时间调用getInstance()方法,如果线程1先进入if块,然后线程2进行控制,那么就会有两个实例被创建。
所以我们需要使用synchronize关键字
//懒汉式单例模式
public class MySingleton {
//设立静态变量
private static MySingleton mySingleton = null;
private MySingleton(){
//私有化构造函数
System.out.println("-->懒汉式单例模式开始调用构造函数");
}
//开放一个公有方法,判断是否已经存在实例,有返回,没有新建一个在返回
public static MySingleton getInstance(){
System.out.println("-->懒汉式单例模式开始调用公有方法返回实例");
if(mySingleton == null){
System.out.println("-->懒汉式构造函数的实例当前并没有被创建");
mySingleton = new MySingleton();
}else{
System.out.println("-->懒汉式构造函数的实例已经被创建");
}
System.out.println("-->方法调用结束,返回单例");
return mySingleton;
}
}
- 饿汉:不懒,一开始就创建单例,空间换时间。线程安全,不用synchronize关键字
/**
* 饿汉式单例模式
* MySingleton2
*/
public static void myprint2(){
System.out.println("-----------------饿汉式单例模式----------------");
System.out.println("第一次取得实例(饿汉式)");
MySingleton2 s1 = MySingleton2.getInstance();
System.out.println("第二次取得实例(饿汉式)");
MySingleton2 s2 = MySingleton2.getInstance();
if(s1==s2){
System.out.println(">>>>>s1,s2为同一实例(饿汉式)<<<<<");
}
System.out.println();
}