【原创】设计模式2:创建型模式-单例(从本人简书博客移入)

本文详细介绍了Java中的单例模式,包括懒汉和饿汉两种实现方式,并针对性能和内存使用进行了优化讨论。推荐的懒汉模式写法是在多线程环境下确保安全的同时提高效率,而饿汉模式则通过内部类实现延迟加载,平衡了初始化时机与内存占用。
摘要由CSDN通过智能技术生成

一、单例

单例指的是整个业务中只有一个实例,这样做能节省内存空间,不用重复创建,使用方便。

单例分为懒汉和饿汉模式,两种模式的代码写法均推荐写法二。

1.懒汉模式

懒汉代码写法一,如下:

public class LazySingleTon {

	private static volatile LazySingleTon instance = null;

	private LazySingleTon() {};

	public static synchronized LazySingleTon sharedInstance() {
		if (instance == null) {
			instance = new LazySingleTon();
		}
		return instance;
	}
}

这种写法因为每回调用调用sharedInstance都需要同步线程,所以多线程大批量操作时会影响效率,所以我们推荐写法2,只有首次为null的时候才锁定线程,之后不为null时,不锁定线程,直接返回instance

public class LazySingleTon {

	private static volatile LazySingleTon instance = null;

	private LazySingleTon() {};

	public static LazySingleTon shareInstance() {
		if (instance == null) {
			synchronized (LazySingleTon.class) {
				if (instance == null) {
					instance = new LazySingleTon();
				}
			}
		}
		return instance;
	}
}

2.饿汉模式

饿汉代码写法一,如下:

public class HungrySingleTon {

	private static final HungrySingleTon instance = new HungrySingleTon();

	private HungrySingleTon(){};

	public static HungrySingleTon sharedInstance() {
		return instance;
	}
}

这种写法,因为采用静态常量的写法,在项目运行初期是一定会new个对象,占用了空间,可以采用内部类的静态常量的写法,这样可以在调用的时候才new个对象,可以节省内存空间。写法二如下:

public class HungrySingleTon {

	private static class HungrySingleTonHolder {
		private static final HungrySingleTon instance = new HungrySingleTon();
	}

	private HungrySingleTon(){};

	public static HungrySingleTon sharedInstance() {
		return HungrySingleTonHolder.instance;
	}
}

以上所有代码均建议采用写法二,可以节省内存空间或减少内存支出~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值