转载请注明出处!!!http://blog.csdn.net/zhonghuan1992
全部配套代码均在github上:https://github.com/ZHONGHuanGit/DesignPattern
跟着ZHONGHuan学习设计模式
抽象工厂
简单介绍:
当每个抽象产品都有多于一个的详细子类的时候,工厂角色怎么知道实例化哪一个子类呢?比方每个抽象产[1] 品角色都有两个详细产品。
抽象工厂模式提供两个详细工厂角色,分别相应于这两个详细产品角色。每个详细工厂角色仅仅负责某一个产品角色的实例化。每个详细工厂类仅仅负责创建抽象产品的某一个详细子类的实例。
每个模式都是针对一定问题的解决方式,工厂方法模式针对的是一个产品等级结构;而抽象工厂模式针对的是多个产品等级结构。(摘自百度百科)
话语说得太抽象,程序猿最好的表示方式是code。当然。我们先用uml类图来直观认识。
UML类图:
从上面的类图中。可以看到,有两个产品族。各自是抽象产品1和抽象产品2这两个产品族,每一个详细工厂可以生产多个产品族的产品。比方详细产品1既生产详细产品11。也生产详细产品21。
产品族:是指位于不同产品等级结构中,功能相关联的产品组成的家族。比方在上图中。详细产品11和详细产品12组成一个产品族。
代码剖析:
//产品族1 interface AbstractProduct1{} class Product11 implements AbstractProduct1{ public Product11(){ System.out.println("生产了产品11"); } } class Product12 implements AbstractProduct1{ public Product12(){ System.out.println("生产了产品12"); } } //产品族2 interface AbstractProduct2{} class Product21 implements AbstractProduct2{ public Product21(){ System.out.println("生产了产品21"); } } class Product22 implements AbstractProduct2{ public Product22(){ System.out.println("生产了产品22"); } } interface AbstractFactory{ AbstractProduct1 createP1();//生产产品族1的产品 AbstractProduct2 createP2();//生产产品族2的产品 } //详细工厂1,由详细工厂1自己决定生产每一个产品族的哪一个产品 class Factory1 implements AbstractFactory{ public AbstractProduct1 createP1(){ return new Product11(); } public AbstractProduct2 createP2(){ return new Product21(); } } //详细工厂2,由详细工厂2自己决定生产每一个产品族的哪一个产品 class Factory2 implements AbstractFactory{ public AbstractProduct1 createP1(){ return new Product12(); } public AbstractProduct2 createP2(){ return new Product22(); } }
抽象工厂和详细工厂的差别:
工厂方法模式:一个抽象产品类。能够派生出多个详细产品类。一个抽象工厂类,能够派生出多个详细工厂类。
每一个详细工厂类仅仅能创建一个详细产品类的实例。
抽象工厂模式:多个抽象产品类,每一个抽象产品类能够派生出多个详细产品类。
一个抽象工厂类,能够派生出多个详细工厂类。每一个详细工厂类能够创建多个详细产品类的实例。
差别:工厂方法模式仅仅有一个抽象产品类。而抽象工厂模式有多个。工厂方法模式的详细工厂类仅仅能创建一个详细产品类的实例,而抽象工厂模式能够创建多个。
什么情况下使用抽象工厂模式:
1一个系统不应当依赖于产品类实例怎样被创建。组合和表达的细节,这对于全部形态的工厂模式都是重要的。
2这个系统的产品多于一个产品族,而系统仅仅消费了当中某一族的产品。
(这一条叫做抽象工厂模式的原使用意)
3同属于一个产品族的产品是在一起使用的。这一约束必须在系统的设计中体现出来。
4系统提供一个产品类的库。全部产品一相同的接口实现,从而是client不依赖于详细实现。
更加符合开闭原则:
开闭原则要求一个软件系统能够在不改动原有代码的情况下,通过扩展达到增强其功能的目的。
而抽象工厂模式对于添加一个新的产品族更加支持。
实例引导:
如果富士康公司给两个品牌作代工产品:苹果和三星。这两个品牌都有手机和平板产品,因为生产工艺的不同。富士康开设了两条生产线,一条线仅仅生产手机。还有一条线仅仅生产平板电脑。苹果公司有新产品公布。向富士康订购生产iPad, 富士康负责人到生产平板的工厂。要求生产苹果的pad,非常快iPad生产出来了。苹果公司又有新款iphone要生产了,向富士康订购。富士康负责人又转身到生产手机的工厂。要求生产iphone,非常快iPhone造好了。
例子类图:
例子代码:
//苹果产品族 interface Apple{} class Iphone implements Apple{//苹果手机 public Iphone(){ System.out.println("生产了iphone"); } } class Ipad implements Apple{//苹果pad public Ipad(){ System.out.println("生产了ipad"); } } //三星产品族 interface SamSung{} class SanSungPhone implements SamSung{//三星手机 public SanSungPhone(){ System.out.println("生产了三星手机"); } } class SamSungPad implements SamSung{//三星平板 public SamSungPad(){ System.out.println("生产了三星平板电脑"); } } //富士康工厂抽象接口 interface FuShiKang{ Apple createApple();//生产苹果产品族的产品 SamSung createSamSung();//生产三星产品族的产品 } //富士康专门生产手机的工厂 class PhoneFactory implements FuShiKang{ public Apple createApple(){//生产苹果手机 return new Iphone(); } public SamSung createSamSung(){//生产三星手机 return new SanSungPhone(); } } //富士康专门生产平板电脑的工厂 class PadFactory implements FuShiKang{ public Apple createApple(){//生产苹果的ipad return new Ipad(); } public SamSung createSamSung(){//生产三星的平板 return new SamSungPad(); } } public class Main{ public static void main(String[] args){ //订购商来到富士康,要订购一台iphone,所以负责人告诉生产手机的工厂加工生产 FuShiKang factory=new PhoneFactory(); Apple iphone= factory.createApple(); //然后要一些三星平板电脑,所以负责人告诉生产平板电脑的工厂加工生产 factory=new PadFactory(); SamSung samsungPad= factory.createSamSung(); } }
结果:
版权声明:本文博客原创文章,博客,未经同意,不得转载。