技术文摘
单例的五种手撕写法
2024-12-30 14:56:46 小编
单例的五种手撕写法
在编程领域中,单例模式是一种常见且实用的设计模式。它确保一个类只有一个实例存在,并提供全局访问点。下面将为您详细介绍单例的五种手撕写法。
一、懒汉式(非线程安全)
这种写法在第一次调用 getInstance 方法时才创建实例,节省了资源,但在多线程环境下可能会创建多个实例。
public class Singleton {
private static Singleton instance;
private Singleton() {}
public static Singleton getInstance() {
if (instance == null) {
instance = new Singleton();
}
return instance;
}
}
二、懒汉式(线程安全)
通过给 getInstance 方法加锁,保证在多线程环境下也只有一个实例被创建,但效率相对较低。
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;
}
}
四、双重检查锁
结合了懒汉式和线程安全的优点,通过两次判断 instance 是否为空来提高效率。
public class Singleton {
private static volatile Singleton instance;
private Singleton() {}
public static Singleton getInstance() {
if (instance == null) {
synchronized (Singleton.class) {
if (instance == null) {
instance = new Singleton();
}
}
}
return instance;
}
}
五、静态内部类
利用 JVM 类加载机制实现线程安全和延迟加载。
public class Singleton {
private Singleton() {}
private static class SingletonHolder {
private static final Singleton INSTANCE = new Singleton();
}
public static Singleton getInstance() {
return SingletonHolder.INSTANCE;
}
}
不同的单例写法各有优缺点,在实际开发中,需要根据具体的业务场景和性能要求选择合适的单例模式实现方式。掌握这些手撕写法,将有助于我们更好地设计和优化代码。
- Hibernate、Spring与Struts的工作原理及使用缘由
- 末代JavaOne大会看点揭秘 生存成疑
- 微软借助Bing推广Silverlight 安装时须切换背景
- Google支持HTML 5 有望成未来应用核心
- JSTL介绍:JSP编程新组件 支持标签编程
- Hibernate批量删除功能解析
- Hibernate中事务管理的解析
- Silverlight版本中LoadMask的浅述
- 深度剖析Hibernate中事务滥用问题
- JavaOne 2009首日:Java软件商店启动 甲骨文CEO亮相
- WebSphere场景应用之业务分析与组件业务服务场景
- WebSphere开发中利用XML Mapping Editor进行映射开发
- 设计模式在IBM WebSphere Portal应用开发中的运用
- Guice与Struts2整合简易教程
- 案例剖析:刚柔并济搭建企业联邦ESB