学而时习,稳固而之心,
好久没有复习java的知识了,今天有空温习了单例模式,这里记录一下
单例模式是常见的设计模式的一种,其特点就是 指一个类只有一个实例,且该类能自行创建这个实例 ,
保证一个类仅有一个实例,并提供一个访问它的全局访问点
看到全局我想到了staic ,昨天晚上听课学习,老师问这个是什么模式,有同学说是单例模式,都没看到static 居然说单例,想想都可怕,我也是赶紧今天补充补充
下面看看单例的几种写法
第一种 饿汉模式
//饿汉模式 public class Singletion { //创建一个静态的类并实例化 private static Singletion instance = new Singletion(); // 私有构造方法 private Singletion() { } //获取唯一可用的对象 public static Singletion getInstance() { return instance; } public void Method(){ System.out.println("单例模式学习"); } }调用
public class Main { public static void main(String[] args) { //获取唯一可用的对象 Singletion singletion = Singletion.getInstance(); //显示 singletion.Method(); } }优点:饿汉模式天生是线程安全的,使用时没有延迟。
缺点:启动时即创建实例,启动慢,有可能造成资源浪费
第二种写法:
懒汉模式(通常也叫饱汉模式)
// 懒汉模式(饱汉模式) public class Singletion { //创建一个静态的类 private static Singletion singleton = null; // 私有构造方法 private Singletion() { } //获取唯一可用的对象 public static Singletion getInstance() { if (singleton==null){ singleton = new Singletion(); } return singleton; } public void Method(){ System.out.println("单例模式学习"); } }方法调用
public class Main { public static void main(String[] args) { //获取唯一可用的对象 Singletion singletion = Singletion.getInstance(); //显示 singletion.Method(); } }优点:懒加载启动快,资源占用小,使用时才实例化,无锁。
缺点:非线程安全。
第三种写法,懒汉添加锁
懒汉模式(饱汉模式) --线程安全
// 懒汉模式(饱汉模式) )--线程安全 public class Singletion { //创建一个静态的类 private static Singletion singleton = null; // 私有构造方法 private Singletion() { } //获取唯一可用的对象 public static synchronized Singletion getInstance() { if (singleton==null){ singleton = new Singletion(); } return singleton; } public void Method(){ System.out.println("单例模式学习"); } }懒加载启动快,资源占用小,使用时才实例化,添加了锁
缺点:synchronized 为独占排他锁,并发性能差。即使在创建成功以后,获取实例仍然是串行化操作。
第四种写法:
懒汉模式(饱汉模式) )--双重加锁检查DCL(Double Check Lock) // 懒汉模式(饱汉模式) )--双重加锁检查DCL(Double Check Lock) public class Singletion { //创建一个静态的类 private volatile static Singletion singleton = null; // 私有构造方法 private Singletion() { } //获取唯一可用的对象 public static Singletion getInstance() { if (singleton==null){ //同步块,线程安全的创建实例 synchronized (Singletion.class){ //再次检查实例是否存在,如果不存在才真的创建实例 if (singleton ==null){ singleton=new Singletion(); } } } return singleton; } public void Method(){ System.out.println("单例模式学习"); } }优点:懒加载,线程安全。
注:实例必须有 volatile 关键字修饰,其保证初始化完全。
第五种写法
Holder模式
// Holder模式 public class Singletion { /** * 类级的内部类,也就是静态的成员式内部类,该内部类的实例与外部类的实例 * 没有绑定关系,而且只有被调用到才会装载,从而实现了延迟加载 */ private static class SingletionHolder { /** * 静态初始化器,由JVM来保证线程安全 */ private static Singletion instance = new Singletion(); } /** * 私有化构造方法 */ private Singletion() { } public static Singletion getInstance() { return SingletionHolder.instance; } public void Method() { System.out.println("单例模式学习"); } }优点:将懒加载和线程安全完美结合的一种方式(无锁)
参考连接
https://www.runoob.com/design-pattern/singleton-pattern.html
https://www.cnblogs.com/t0000/p/8250686.html
胡小牧 认证博客专家 Android Java 小程序 岁月推动着年华,伴随着流水的脚步走过春夏秋冬。回想一路走来磕磕绊绊,感谢前辈们的无私奉献,本文重在共享,欢迎大家转载,评论,指教,点赞,谢谢,如果您对文章存在疑问,或者和您的文章类似,请私信,----------------期待是心痛的根源,心不动,则不痛。