单例模式(Singleton Pattern)

一、单例模式介绍

①定义:
指一个类只有一个实例,且该类能自行创建这个实例的一种模式。

②特点:

  1. 单例类只有一个实例对象;
  2. 该单例对象必须由单例类自行创建;
  3. 单例类对外提供一个访问该单例的全局访问点;

③优缺点:
优点:

  • 在内存里只有一个实例,减少了内存的开销,尤其是频繁的创建和销毁实例(比如管理学院首页页面缓存);
  • 避免对资源的多重占用(比如写文件操作)。

缺点:

  • 没有接口,不能继承,与单一职责原则冲突,一个类应该只关心内部逻辑,而不关心外面怎么样来实例化。

④使用场景

  1. 要求生产唯一序列号。
  2. WEB 中的计数器,不用每次刷新都在数据库里加一次,用单例先缓存起来。
  3. 创建的一个对象需要消耗的资源过多,比如I/O 与数据库的连接等。

二、代码实现
①懒汉式,线程不安全

public class Singleton{
	private static Singleton instance;
	private Singleton (){}
	public static Singleton getInstance (){
		if(instance ==null){
			instance =new Singleton();
		}
		return instance;
	}
}

②懒汉式,线程安全

public class Singleton{
	private static Singleton instance;
	private Singleton (){}
	public static synchronized Singleton getInstance (){
		if(instance == null ){
		   instance=new Singleton();
		}
		return instance;
	}
}

③饿汉式

//线程安全
public class Singleton{
	private static Singleton instance=new Singleton();
	private Singleton (){}
	public static Singleton getInstance (){
		return instance;
	}
}

④双检锁/双重校验

//线程安全
public class Singleton{
	private volatile static Singleton singleton;
	private Singleton (){}
	public static Singleton getSingleton (){
		if(singleton == null ){
			synchronized(Singleton.class){
				if(singleton == null){
					singleton=new Singleton();
				}
			}
		}
		return singleton;
	}
}

⑤登记式/静态内部类

//线程安全
public class Singleton{
	private static class SingletonHolder{
		private static final Singleton INSTANCE=new Singleton();
	}
	private Singleton (){}
	public static final Singleton getInstance (){
		return SingletonHolder.INSTANCE;
	}
}

⑥枚举

//线程安全
public enum Singleton{
	INSTANCE;
	public void whateverMethod () {}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值