今天又一次拿起java与模式一书,细看了单列模式
单例模式分为三种:1.饿汉模式,2.懒汉模式,3.登记模式
饿汉模式:在自己被加载时就将自己实例化,即便加载器是静态的
package singleton; public class EagerSingleton { private static final EagerSingleton eagerSingleton = new EagerSingleton(); private EagerSingleton(){} public static EagerSingleton getInstance() { return eagerSingleton; } }
懒汉模式:如果类加载器是静态的,那么懒汉式单例类被加载时不会将自己实例化
package singleton; public class LazySingleton { private static LazySingleton lazySingleton; private LazySingleton(){} public synchronized static LazySingleton getInstance() { if (lazySingleton == null) { lazySingleton = new LazySingleton(); } return lazySingleton; } }
登记模式:是为了克服饿汉式单例类及懒汉式单例类均不可继承的缺点而设计的。他的子类实例化的方式只能是懒汉式
package singleton; import java.util.HashMap; import java.util.Map; //父类 public class RegisterSingleton { private static Map m_registry = new HashMap(); static { RegisterSingleton registerSingleton = new RegisterSingleton(); m_registry.put(registerSingleton.getClass().getName(), registerSingleton); } /** * 保护的默认构造子 */ protected RegisterSingleton() { } public static RegisterSingleton getInstance(String name) { if (null == name) { name = "singleton.RegisterSingleton"; } if (m_registry.get(name) == null) { try { m_registry.put(name, Class.forName(name).newInstance()); } catch (InstantiationException e) { e.printStackTrace(); } catch (IllegalAccessException e) { e.printStackTrace(); } catch (ClassNotFoundException e) { e.printStackTrace(); } } return (RegisterSingleton) m_registry.get(name); } } //子类 package singleton; public class RegisterSingletonChild extends RegisterSingleton { public RegisterSingletonChild() { } public static RegisterSingletonChild getInstance() { return (RegisterSingletonChild) RegisterSingleton.getInstance("singleton.RegisterSingletonChild"); } }
由于子类必须允许父类以构造子调用产生实例,因此,它的构造子必须是公开的。这样一来,就等于允许了以这样方式产生实例而不在父类中登记,这是登记式单例模式的一个缺点。
双重检查成例的研究:
是对于懒汉模式的一种改进;因为在第一次调用后,对象已经被实例化,所以再次调用时的同步化就变成了一个不必要的瓶颈,
所以就有了如下的改进:
package singleton; public class LazySingleton { private static LazySingleton lazySingleton; private LazySingleton(){} public static LazySingleton getInstance() { if (lazySingleton == null) { synchronized(LazySingleton.class) { if (null == lazySingleton) { lazySingleton = new LazySingleton(); } } } return lazySingleton; } }
但是有说Java语言编译器里面不支持双重检查:具体原因好像是说在java编译器中,LazySingleton类的初始化与lazySingleton变量赋值的顺序不可预料。如果一个线程在没有同步化的条件下读取lazySingleton引用,并调用这个对象的方法的话,可能会发现对象的初始化过程尚未完成,从而造成崩溃。
对于这个说法我反正没有验证过。
下面来说说单例的状态:
主要分为有状态的单例类和没有状态的单例类:
一个单例类可以是有状态的,一个有状态的单例对象一般也是可变单例对象。
有状态的可变的单例对象常常当做状态库使用,不如一个单例对象可以持有一个int类型的属性,
用来给一个系统提供一个数值唯一的序列号码,作为某个贩卖系统的账单号码。
当然,一个单例类可以持有一个聚集,从而允许存储多个状态。
一个单例类也可以是没有状态的,仅用作提供工具性函数的对象,既然是为了提供工具性函数,
也就没有必要创建多个实例,因此使用单例模式很适合,一个没有状态的单例类也就是不变单例类
具体可以参见:http://www.iteye.com/topic/959751和http://www.iteye.com/topic/960532
相关推荐
单例模式单例模式单例模式单例模式单例模式单例模式单例模式单例模式
C#单例模式C#单例模式详解C#单例模式详解C#单例模式详解
单例模式详解~~单例模式详解~~单例模式详解~~
2020-02-10 王争设计模式之美进入课程讲述:冯永吉时长 10:21大小 8.31M上两节课中,我们针对单例模式,讲解了单例的应用场景、几种常见的代码实现
首先向关注过我这个系列...这立刻让我想到了最常用也是最简单最容易理解的一个设计模式 单例模式 何为 单例模式 ? 故名思议 即 让 类 永远都只能有一个实例。 由于 示例代码 比较简单 我也加了注释,这里就不在赘述
单例模式是最简单的设计模式之一,但是对于Java的开发者来说,它却有很多缺陷。在本月的专栏中,David Geary探讨了单例模式以及在面对多线程(multithreading)、类装载器(classloaders)和序列化(serialization)时...
单例模式的七种实现方法以及分析,可以作文大作业提交 1.前言 4 1.1 课题的研究背景 4 1.2 课题主要研究目标 4 2.相关技术简介 4 2.1Java简介 4 2.2IDEA简介 4 3. 单例模式的7种实现方式 5 3.1饿汉式(使用静态常量...
一个简单的java工程,包含注释,一目了然,其中包含了单例模式的所有实现方式,懒汉式,饿汉式,双重校验,枚举,静态内部类等方式实现单例。
单例模式--只能弹出一个窗体 只能弹出一个窗体
设计模式之七种单例模式代码及ppt,包含多线程环境测试和反序列化测试
单例模式和工厂模式结合应用,实现了产品的生产,适合用做课程设计,包含详细文档和代码。Java语言。喜欢的可以下载来看看那
几种单例模式的书写方式
使用单例模式创建学生管理系统(饿汉式、懒汉式)
php单例模式php单例模式php单例模式php单例模式
模式就像是OOP开发人员的配方,每种模式都提供了所需的成分。模式对OOP开发人员尤其有用,因为它有助于创建稳定的API,...本章将介绍两种常用的模式:单例模式和工厂模式。前者被称为类的职责,后者被称为类的多态性。
这个讲的是单例模式的多种不同实现方式,希望对单例感兴趣的同学看看
是http://blog.csdn.net/lxq_xsyu/article/category/1544127博客中java设计模式的源代码。下载前请先看《设计模式——单例模式》一文。
Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式Java SE程序 单例模式...
设计模式C++学习之单例模式(Singleton)
此示例展示了Qml 的单例模式(类似全局对象,只生成一次实例,可全局使用) surfsky.cnblogs.com