网站首页 > java教程 正文
单例模式
是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中,应用该模式的一个类只有一个实例。即一个类只有一个对象实例。
- 单例类只能有一个实例。
- 单例类必须自己创建自己的唯一实例。
- 单例类必须给所有其他对象提供这一实例。
懒汉式
当第一次调用的时候才会创建对象,合理占用资源。
/** * 懒汉式(线程安全) */ public class Singleton01 { private static Singleton01 singleton01; // 私有构造方法 private Singleton01() { } // 同步获取单例对象,保证线程安全 public static synchronized Singleton01 getInstance() { // 单例对象为空的时候,创建单例对象 if (singleton01 == null) { singleton01 = new Singleton01(); } return singleton01; } }
饿汉式
类加载的时候就会初始化,他是线程安全的,但是类加载的时候就会初始化会预先消耗一部分资源。
/** * 饿汉式 */ public class SingleTon02 { private static SingleTon02 singleTon02 = new SingleTon02(); // 私有构造方法 private SingleTon02() { } public static SingleTon02 getInstance() { return singleTon02; } }
双检索式
该方式能保证需要的时候才初始化单例,还能保证线程安全,而且单例初始化的时候调用getInstance()不会进行同步锁。
/** * 双检索(DCL式). */ public class Singleton03 { private volatile static Singleton03 singleton03; // 私有构造方法 private Singleton03() { } // 同步该方法获取单例对象 public static Singleton03 getInstance() { // 但对象为空时同步这个方法 if (singleton03 == null) { synchronized (Singleton03.class) { // 再判断是否为空 if (singleton03 == null) { // 为空的话就创建对象 singleton03 = new Singleton03(); } } } return singleton03; } }
静态内部类
内部类只有在getInstance()方法第一次调用的时候才会被加载(实现了延迟加载效果),而且其加载过程是线程安全的(实现线程安全)。内部类加载的时候只实例化了一次instance
/** * 静态内部类,推荐该该方式实现单例模式. */ public class Singleton04 { // 私有化构造方法 private Singleton04() { } /** * 静态内部类. * 内部类只有在getInstance()方法第一次调用的时候才会被加载(实现了延迟加载效果), * 而且其加载过程是线程安全的(实现线程安全)。内部类加载的时候只实例化了一次instance */ private static class Singleton05inner { public static final Singleton04 INSTANCE = new Singleton04(); } public static Singleton04 getInstance() { return Singleton05inner.INSTANCE; } }
枚举
枚举是线程安全的,而且任何情况下都是一个实例,枚举不能实例化,不能被反射。
/** * 枚举. */ public enum Singleton05 { INSTACNE; public static Singleton05 getInstacne() { return INSTACNE; } }
容器实现单例
容器实现单例,它的好处是可以统一管理单例。
/** * 容器实现单例. * 它的好处是可以统一的管理单例,安卓中getSystemService(String name)就是用这种方式实现的. */ public class Singleton06 { private static Map<String, Object> singletonManagerMap = new HashMap<>(); // 私有构造方法 private Singleton06() { } // 注入程序中的单例 public static void registerSingleton(String key, Object instance) { if (!singletonManagerMap.containsKey(key)) { singletonManagerMap.put(key, instance); } } // 获取key值对应的单例对象 public static Object getInstance(String key) { return singletonManagerMap.get(key); } }
猜你喜欢
- 2024-09-22 带你了解单例模式(Singleton Pattern)的五种写法!
- 2024-09-22 单例模式的常用写法(单例模式三种写法)
- 2024-09-22 GoF之单例模式详解(单例模式在哪里使用)
- 2024-09-22 设计模式之-单例模式(单例设计模式的作用)
- 2024-09-22 Java(面试)——单例模式(java中单例模式的实现)
- 2024-09-22 在Java中实现单例模式(java单例模式实现方式)
- 2024-09-22 Java单例模式(java单例模式双重检查)
- 2024-09-22 Java设计模式之单例模式解析(java 单例模式 例子)
- 2024-09-22 本文将给大家介绍java中设计模式——单例模式
- 2024-09-22 java面试:单例模式,一篇就够了(java单例模式写法)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)