- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
单例设计模式懒汉式设计
单例设计模式懒汉式设计:
一般来说,单例设计模式两种常用的设计方法就是饿汉式和懒汉式。两者的设计思路是一样的,只不过在实现的过程中有点小区别。具体在下面结合代码讲解。
第一步:定义私有的static成员变量,和饿汉式不同的是,这里只是定义变量,并不直接创建实例对象
public class Singleton {
private static Singleton single;
}
第二步:将构造方法私有化,保证只能在内部进行调用
public class Singleton {
private static Singleton single;
private Singleton(){}
}
第三步:提供一个public的static方法,供外部访问唯一的示实例对象
public class Singleton {
private static Singleton instance;
private Singleton() {}
/**
这个方法并不是直接返回instance,它首先需要判断实例对象是否创建,如果没有创建,则创建,然后返回instance,如果已经创建,则直接返回instance.
当第一次使用的时候,在内存中是不存在该实例对象的,所以第一次调用 getInstance方法的时候会创建实例对象,然后在以后的使用中都不会进行再次创建,就是使用第一次创建的对象.这样就保证了对象的唯一性。
*/
public static Singleton getInstance() {
if (null == instance) {
instance = new Singleton();
}
return instance;
}
}
通过以上三步,就完成了单例对象的创建,看起来和饿汉式的设计方式区别并不大,只是一个是在需要使用的时候再进行创建;一个是随着类的加载而创建,在使用之前就已经创建好了对象.当我们在设计单例的时候,如果该实例对象占用的内存较大,而使用它的时候又比较晚,我们通常可以选用懒汉式这种设计方式,这样比较节省内存,因为它不用一开始就占着内存不放,而是在使用它的时候才开始创建.这也就是所谓的懒加载或延迟加载。
但是在硬件飞速发展的今天,这么一点点小内存应该不是问题了,所以还是建议使用饿汉式的设计方式,因为上面的那种设计方式存在着线程安全问题,当只有单个线程进行访问的时候是没有问题的,但是当有多个线程并发访问的时候,就会出现线程安全问题:可能会出现多次创建实例对象的情况(后面创建的实例会把前面创建的实例覆盖)。
怎样产生的线程安全问题,在这里先不进行解释,改进的办法如下(用同步方法即可):
public class Singleton {
private static Singleton instance;
private Singleton() {}
/*
用同步方法就可以保证只有最先的那个线程创建一次实例对象,以后的线程都不会进行创建,但当用了同步方法之后,效率就会明显降低,因为每次只有一个线程能够访问该方法,只有等一个线程结束访问之后,下一个线程才能够进行访问.
*/
public static synchronized Singleton getInstance() {
if (null == instance) {
instance = new Singleton();
}
return instance;
}
}
因为同步方法每次只能有一个线程进入,所以效率较低,为了提高一点效率,对上面的方法进行优化,如下所示(不使用同步方法,改成使用同步代码块):
public class Singleton {
private static Singleton instance;
private Singleton() {}
/*
当将同步方法改成同步代码块之后,效率就会明显的提高,当最先的线程进入同步代码块中将实例创建好之后,以后的线程就不会再进入同步代码块中,只会进行一次判断(这时候的实例对象已经创建好了)就直接返回instance.
这样效率相对于上面的那种形式会高很多,但相对于饿汉式还是差一点,因为多了一个判断嘛.
*/
public static Singleton getInstance() {
if (null == instance) {
synchronized (Singleton.class) {
if (null == instance) {
instance = new Singleton();
}
}
}
return instance;
}
文档评论(0)