今天看了一篇关于工厂模型的博文。感觉不错,可谓感触颇深,对工厂模型的理解有进一步。下面我也简单介绍一下工厂模型。
工厂模型主要分为以下三种状态:
(1).简单工厂模型(SimpleFactory)
(2)工厂方法(Factory Method)
(3)抽象工厂(Abstract Factory)
1.简单工厂模型:其实就是定义一个接口,不同的产品类实现这个接口,最后工厂类通过传入的不同参数去生产不同的产品。这里的核心就是工厂类。下面介绍一个小例子。
假设我们要生产手机和电脑该怎么办呢?
首先先定义一个产品Product接口
public interface Product { }
要生产手机和电脑就得分别定义电脑类和手机类。
电脑类:
public class Computer implements Product{ public Computer(){ System.out.println("电脑被制造出来了"); } }
手机类:
public class Phone implements Product{ public Phone(){ System.out.println("电话被制造出来了"); } }
这个时候呢就需要工厂出面了。根据传入的参数不同,就代表了不同的需求,生产不同的产品。
简单工厂类:
public class SimpleFactory { public static Product Factory(String productName)throws Exception{ if("phone".equals(productName)){ return new Phone(); }else if("computer".equals(productName)){ return new Computer(); }else{ throw new Exception("没有改产品"); } } }
下面我们写个测试类,看一下运行结果:
测试类:
public class TestSimpleFactory { public static void main(String[] args) { try{ SimpleFactory.Factory("computer"); SimpleFactory.Factory("phone"); }catch(Exception e){ e.printStackTrace(); } } }
测试结果为:
电脑被制造出来了
电话被制造出来了
这就是简单工厂,但是简单工厂尤其局限性。简单工厂的核心就是工厂类。一旦工厂类失效,则整个程序就会失效。所以就有了工厂方法和抽象工厂。下面先介绍一下工厂方法。
2工厂方法:简单的说工厂方法就是给工厂定义了接口,通过多态的形式削弱了工厂的作用。
工厂的接口:定义了一个抽象方法。
public interface Factory { public Product create(); }
和上面一样也定义了一个产品接口:用于实现不同产品的生产。
产品接口:
public interface Product { }
既然有了产品接口就生产不同的产品吧。
手机类:
public class Phone implements Product{ public Phone(){ System.out.println("电话被制造出来了"); } }
电脑类:
public class Computer implements Product{ public Computer(){ System.out.println("电脑被制造出来了"); } }
工厂方法的最主要特点就是定义了工厂接口,可以定义出专门生产电脑的工厂,也可以定义出专门生产手机的工厂等等。。。下面就定义工厂的实现类吧
电脑工厂类:专门生产电脑
public class ComputerFactory implements Factory { public Product create() { return new Computer(); } }
手机工厂类:专门生产手机
public class PhoneFactory implements Factory{ public Product create() { return new Phone(); } }
下面我们写一下工厂方法类:主要创建不同的工厂类,通过不同的工厂生产不同的产品。
工厂方法类:
public class FactoryMethod { public static void main(String[] args) { ComputerFactory cf = new ComputerFactory(); cf.create(); PhoneFactory pf = new PhoneFactory(); pf.create(); } }
下面看一下运行结果:
电脑被制造出来了
电话被制造出来了
接下来介绍一下抽象工厂类。之后在总结一下三者的区别。
3抽象工厂类:就是现在的产品更加丰富,就像联想电脑还有不同的型号,而不是单一的一种型号。这是对产品的接口就得更加细化。例如手机和电脑不在简单的定义一个产品接口就可以,而是的对其分别定义不同的接口:下面我们就对其定义接口如下:
手机接口:
public interface Phone { }
电脑接口:
public interface Computer { }
有了接口我们就可以通过接口实现不同的产品类了:
手机产品类:
(1)联想手机类:
public class LenovoPhone implements Phone{ public LenovoPhone(){ System.out.println("联想手机被生产出来了"); } }
(2)苹果手机类:
public class ApplePhone implements Phone{ public ApplePhone(){ System.out.println("苹果手机被生产出来了"); } }
电脑产品类:
(1)联想电脑类:
public class LenovoComputer implements Computer{ public LenovoComputer(){ System.out.println("联想电脑被生产出来了"); } }
(2)苹果电脑类:
public class AppleComputer implements Computer{ public AppleComputer(){ System.out.println("苹果电脑被生产出来了"); } }
对了我们还需要创建一个工厂类接口:这个接口与前面的有所不同。请看
public interface Factory { public Computer createComputer(); public Phone createPhone(); }
这个工厂接口不仅有电脑抽象方法还有手机的抽象方法。就像联想工厂的创建不仅仅是为了生产电脑,而是为了能生产联想的各种电子产品。下面定义联想工厂实现类:
联想工厂实现类:
public class LenovoFactory implements Factory{ public Phone createPhone() { return new LenovoPhone(); } public Computer createComputer() { return new LenovoComputer(); } }
苹果工厂的实现类:
public class AppleFactory implements Factory{ public Computer createComputer() { return new AppleComputer(); } public Phone createPhone() { return new ApplePhone(); } }
下面写个测类,看下结果。
测试类:定义不同的工厂对象,进行产品生产。
public class TestAbstractFactory { public static void main(String[] args) { LenovoFactory lf = new LenovoFactory(); lf.createComputer(); lf.createPhone(); AppleFactory af = new AppleFactory(); af.createComputer(); af.createPhone(); }
运行结果:
联想电脑被生产出来了
联想手机被生产出来了
苹果电脑被生产出来了
苹果手机被生产出来了
三种工厂方法已经介绍了,现在总结一下三个方法的区:
简单工厂模型就是这个工厂什么都能生产,工厂的作用比较大,一旦工厂出现问题则所有的产品都不能生产,在这里工厂是当之无愧的核心所在。而工厂方法呢,则削弱了工厂的核心作用。给工厂定义了接口,可以实现不同工厂类,一旦那个工厂出现问题其他工厂照样可以生产产品。但是唯一的不足是一个工厂只能生产单一的产品。而抽象工厂类实现一个工厂生产不同的产品。抽象工厂类和工厂方法各有各的特点,各有所长,使用与不同的生产模式。