单例模式又叫做 Singleton模式,自己把类设计好给别人用,不能在自己创建的里边用,那样就不是单例模式了。指的是一个类,在一个JVM里,只有一个实例存在。
具体:
LOL里有一个怪叫大龙GiantDragon,只有一只,所以该类,只能被实例化一次。
饿汉式单例模式
GiantDragon 应该只有一只,通过私有化其构造方法,使得外部无法通过new 得到新的实例。
GiantDragon 提供了一个public static的getInstance方法,外部调用者通过该方法获取12行定义的对象,而且每一次都是获取同一个对象。 从而达到单例的目的。
这种单例模式又叫做饿汉式单例模式,无论如何都会创建一个实例
创建GiantDragon类
package com.ly.singleton;
public class GiantDragon {
//私有化构造方法使得该类无法在外部通过new进行实例化
private GiantDragon(){
}
//准备一个类属性,指向一个实例化对象。因为是类属性,所以只有一个,只有自己能创建实例对象
private static GiantDragon instance=new GiantDragon();
//public static方法,提供给调用者获取12行定义的对象
public static GiantDragon getGetInstance(){
return instance;
}
}
package com.ly.singleton;
public class TestDiagon {
public static void main(String[] args) {
//报错,因为只能有一个实例对象
// GiantDragon giantDragon=new GiantDragon();
//只能通过getGetInstance获取对象
GiantDragon g1=GiantDragon.getGetInstance();
GiantDragon g2=GiantDragon.getGetInstance();
GiantDragon g3=GiantDragon.getGetInstance();
//都是同一个对象
System.out.println(g1==g2);//true
System.out.println(g1==g3);//true
System.out.println(g2==g3);//true
}
}
懒汉式单例模式与饿汉式单例模式不同,只有在调用getInstance的时候,才会创建实例
package com.ly.singleton;
public class GiantDragon {
//私有化构造方法使得该类在外部通过new进行实例化
private GiantDragon(){
}
//准备一个类属性,指向一个实例化对象。因为是类属性,所以只有一个
private static GiantDragon instance=new GiantDragon();
//public static方法,提供给调用者获取12行定义的对象
public static GiantDragon getGetInstance(){
return instance;
}
}
test部分同饿汉式,但是一直指向的也是同一个对象。
饿汉式是立即加载的方式,无论是否会用到这个对象,都会加载。
如果在构造方法里写了性能消耗较大,占时较久的代码,比如建立与数据库的连接,那么就会在启动的时候感觉稍微有些卡顿。
懒汉式,是延迟加载的方式,只有使用的时候才会加载。 并且有线程安全的考量。
使用懒汉式,在启动的时候,会感觉到比饿汉式略快,因为并没有做对象的实例化。 但是在第一次调用的时候,会进行实例化操作,感觉上就略慢。
看业务需求,如果业务上允许有比较充分的启动和初始化时间,就使用饿汉式,否则就使用懒汉式
什么是单例模式?
1.构造方法私有化
2.静态属性指向实例
3.public static 的getInstance()方法,返回第二步的静态属性。