单例模式
饿汉式和懒汉式
1、饿汉式
①结构器私有化(避免在类的内部能够间接创立(new))
②在类的外部间接创建对象
③提供一个公共的静态方法,返回对象
public class SingleTonTest {public static void main(String[] args) {GrilFriend instance = GrilFriend.getInstance();
GrilFriend instance1 = GrilFriend.getInstance();
System.out.println(instance1 == instance);
}
}
class GrilFriend {
private static age = 18
private String name;
private static GrilFriend gf = new GrilFriend("aa");
private GrilFriend(String name) {System.out.println("结构器被执行......");
this.name = name;
}
public static GrilFriend getInstance() {return gf;}
}
2、懒汉式 单例模式
①结构器私有化(避免在类的内部能够间接创立(new))
②定义一个动态的对象属性
③提供一个公共的静态方法 返回对象(如果没有创建对象,则创立一个,创立过了则返回对象)
④懒汉式,只有当用户应用 getInstance 办法时,才会返回对象,而后再次调用时返回上次创立的对象从而保障了单例
class GrilFriend {
private static age = 18
private String name;
private static GrilFriend gf;
private GrilFriend(String name) {System.out.println("结构器被执行......");
this.name = name;
}
public static GrilFriend getInstance() {if (gf == null) {gf = new GrilFriend("aa");
}
return gf;
}
}
饿汉式 VS 懒汉式
- 二者最次要的区别在于创建对象的机会不同:饿汉式是在类加载就创立了对象实例,而懒汉式是在应用时才创立。
- 饿汉式不存在线程平安问题,懒汉式存在线程平安问题(多个线程同时调用时,对象没创立完就会导致创立多个对象)
- 饿汉式存在浪费资源的可能,懒汉式则没有
- 在 JavaSE 规范类中,java.lang.Runtime 就是经典的饿汉式单例模式