【算法】实现单例模式Java

本文介绍了单例模式的概念和重要性,包括饿汉式和懒汉式的实现方式。饿汉式在类加载时就创建单例,保证线程安全;而懒汉式在多线程环境下需要额外的同步措施来确保正确初始化。文章提供了相关资源以深入理解单例模式和多线程。
摘要由CSDN通过智能技术生成

1 单例模式介绍

单例模式(Singleton)是一种常用的软件设计模式。在应用这个模式时,单例对象的类必须保证只有一个实例存在。许多时候整个系统只需要拥有一个的全局对象,这样有利于我们协调系统整体的行为。比如在某个服务器程序中,该服务器的配置信息存放在一个文件中,这些配置数据由一个单例对象统一读取,然后服务进程中的其他对象再通过这个单例对象获取这些配置信息。这种方式简化了在复杂环境下的配置管理。

三要素:

  • 私有的构造方法;
  • 指向自己实例的私有静态引用;
  • 以自己实例为返回值的静态的公有方法。

2 饿汉式

单线程下:

public class SingletonClass{
	private static final SingletonClass instance=new SingletonClass();
	//私有构造函数
	private SingletonClass(){}
	public static SingletonClass getInstance(){
		return instance;
	}
}

多线程下:
单例类被加载时,就会实例化一个对象并交给自己的引用,供系统使用。在线程访问单例对象之前就已经创建好了。再加上,由于一个类在整个生命周期中只会被加载一次,因此该单例类只会创建一个实例,也就是说,线程每次都只能也必定只可以拿到这个唯一的对象。所以说,饿汉式单例模式天生的多线程安全。

3 懒汉式

单线程下:

public class SingletonClass{
	private static SingletonClass instance=null;
	//私有构造函数
	private SingletonClass(){}
	public static SingletonClass getInstance(){
		if(instance==null){
			instance=new SingletonClass();
		}
		return instance;
	}
}

多线程线程下:有可能会有多个线程同时进入 if (singleton2 == null) {…} 语句块的情形发生。当这种这种情形发生后,该单例类就会创建出多个实例,违背单例模式的初衷。因此,传统的懒汉式单例是非线程安全的。

解决:在getInstance方法上加上synchronized修饰就好

public class SingletonClass{
	private static SingletonClass instance=null;
	//私有构造函数
	private SingletonClass(){}
	public synchronized static SingletonClass getInstance(){
		if(instance==null){
			instance=new SingletonClass();
		}
		return instance;
	}
}

参考
https://www.cnblogs.com/yoga21/p/9224557.html 彻头彻尾理解单例模式与多线程
https://blog.csdn.net/justloveyou_/article/details/52464440 Java 中的 ==, equals 与 hashCode 的区别与联系

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值