懒汉和饿汉模式

本文详细解析了懒汉模式和饿汉模式在单例设计模式中的应用。懒汉模式在类加载时并不初始化,而是在第一次调用getInstance方法时才进行实例化,这种方式在多线程环境下可能产生并发问题,需使用synchronized关键字解决。饿汉模式则在类加载时就完成了初始化,不存在线程安全问题,但可能会造成资源浪费。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

懒汉模式

1.构造私有
2.直接在类体中new出唯一对象,注意有可能产生线程并发问题

public class LazySingleton {

private LazySingleton() {
	// TODO Auto-generated constructor stub
}

private static LazySingleton lazySingleton;

/**
 * 在public中new出唯一对象
 * 在方法体中创建该唯一对象有可能产生线程并发问题
 * 加synchronize同步锁
 */
public static LazySingleton getInstance(){
	if(lazySingleton==null){
		lazySingleton = new LazySingleton();
	}
	return lazySingleton;
}
}

线程安全

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

饥汉/饿汉模式

1.构造私有
2.直接在类体new出唯一对象
3.添加public方法返回唯一对象

public class EagerSingleton {

//构造方法私有
private EagerSingleton() {
	// TODO Auto-generated constructor stub
}

//new出唯一对象
private static final EagerSingleton EAGER_SINGLETON
	= new EagerSingleton();

/**
 * 添加public方法,让外界能够访问该唯一对象
 */
public static EagerSingleton getInstance(){
	return EAGER_SINGLETON;
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值