工厂模式与单例模式

这篇文主要是给大家以简单工厂模式结合单例模式一起使用。

我们先简单的复习一下简单工厂模式核心和优缺点。

简单工厂模式核心:

简单工厂模式就是专门负责将大量有共同接口的类实例化,而且不必事先知道每次是要实例化哪个一个类的模式。它定义一个用与创建对象的接口,由子类决定实例化哪一个类,根据外界传递的信息来决定创建哪个具体类的对象。

简单工厂模式的优缺点:

优点:它的核心是工厂类,这个类负责产品的创建,而客户端可以免去产品创建的责任,这实现了责任的分割。

缺点:由于工厂类集中了所有产品创建逻辑,如果不能正常工作的话会对系统造成很大的影响。如果增加新产品必须修改工厂类的代码。


下面就给大家直接贴一个简单工厂模式的代码图:

1、首先,定义一个产品抽象类。


2、在创建两个具体对象类,实现该产品抽象类

    我们来创建一个奥迪A4车类。


    再创建一个国产车宝骏740车类。


    好了,具体类我们已经创建好了,剩下的就是该创建生产类了。


    接下来我们就可以使用客户端调用生产类而来创建具体对象了。

    客户端调用生产类实例化对象代码:


    运行结果:


这就是整个简单工厂模式的实例代码了,复习简单工厂模式就先到这里,我们先来讲一下在Java中的单例模式。

首先了解一件事物之前,我们得搞懂该事物的优点,这样我们才能足够兴趣去了解,下面就给大家介绍一下单例模式的优点。

单例模式主要作用是保证在Java应用程序中,一个类Class只有一个实例存在。 使用Singleton的好处还在于可以节省内存,因为它限制了实例的个数,有利于Java垃圾回收(garbage collection)。

单例模式主要分为两种:1、懒汉式单例,2、饿汉式单例。我们下面来讲讲这两种类型有什么优缺点和到底如何编写。

首先,我们来介绍饿汉式单例模式,废话少说,直接贴代码:


    这种写法就是所谓的单例的饿汉模式,该缺点也能一眼辨出,就是对象在没使用之前就已经在内存中实例化了,这就带来了一个潜在的性能问题,如果这个对象很大呢?所以就又衍生出了懒汉模式,下面给大家讲解一下懒汉模式的写法。


这就是所谓的懒汉模式,它沿用了一种设计思想-延迟加载,也就是我没用到这个对象时是不会去实例化的。

在上面两种单例模式的写法当中它们都有一个相同的地方,那就是要私有化构造函数,私有构造函数就是为了防止外界去new该对象。

但是懒汉模式就没有了缺点吗?不,该模式是存在线程不安全的缺点的,可是该怎么写才能防止线程安全且性能没隐患的单例模式呢?

好的,下面就给大家贴一个线程安全且没有性能隐患的单例模式。


下面给大家简单的介绍该代码片段:

如果有三个线程同时到getInstance函数时的第一个if语句时,会有两个线程为等待状态,不为等待状态的线程实例化完后,剩下的线程再判断则为是已经实例化的了,所以这就做到了把同步粒度减少到了最低。

声明doubleBlockSingleton变量时用到了volatile关键字,改关键字的作用是:当doubleBlockSingleton变量被初始化成DoubleBlockSingleton实例时,多个线程正确地实例了doubleBlockSingleton变量。如果性能是你关心的重点,那么这个做法可以帮你大大地减少getInstance()的时间耗费。

我们最后在总结一下单例模式:

单例模式(Singleton)

    1)单例模式只能有一个实例

    2)单例模式必须自己创建自己的实例。

    3)单例模式必须给所有其它对象提供这一个实例

单例模式主要分为两种:

    一、懒汉式单例

    二、饿汉式单例

懒汉式和饿汉式的区别:

    懒汉式是在你真正用到的时候才去建这个对象。

    饿汉式是在你没用到的时候就已经建好对象了。

两种单例的要素:

    1、私有的构造方法

    2、指向自己实例的私有静态引用

    3、以自己实例为返回值的静态的公有方法

单例模式就介绍到这里了,可是工厂和单例该怎么结合使用呢?下面我就简单的贴一段代码,剩下的就是要靠你们去思考喽。

就拿简单工厂模式的生产类做例子:


客户端代码:


运行结果:


关于简单工厂模式与单例模式就介绍到这里,如果大家还有什么疑问欢迎到留言区留言哦。


请关注微信公众号:请快点喜欢我

你可能感兴趣的:(工厂模式与单例模式)