Java设计模式:单例模式

mac2024-06-01  38

学而时习,稳固而之心,

好久没有复习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 小程序 岁月推动着年华,伴随着流水的脚步走过春夏秋冬。回想一路走来磕磕绊绊,感谢前辈们的无私奉献,本文重在共享,欢迎大家转载,评论,指教,点赞,谢谢,如果您对文章存在疑问,或者和您的文章类似,请私信,----------------期待是心痛的根源,心不动,则不痛。
最新回复(0)