2016.12.28 学习日记-抽象工厂模式

今天设计模式结课了,自己才学习了一半,得加油了,近期几门考试都是弱项,加油复习!!!今天学习的是虚拟工厂模式


虚拟工厂模式

抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态。抽象工厂模式是指当有多个抽象角色时,使用的一种工厂模式。抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体的情况下,创建多个产品族中的产品对象。根据里氏替换原则,任何接受父类型的地方,都应当能够接受子类型。因此,实际上系统所需要的,仅仅是类型与这些抽象产品角色相同的一些实例,而不是这些抽象产品的实例。换言之,也就是这些抽象产品的具体子类的实例。工厂类负责创建抽象产品的具体子类的实例。


角色:

抽象工厂(Abstract Factory)角色:担任这个角色的是工厂方法模式的核心,它是与应用系统商业逻辑无关的。

具体工厂(Concrete Factory)角色:这个角色直接在客户端的调用下创建产品的实例。这个角色含有选择合适的产品对象的逻辑,而这个逻辑是与应用系统的商业逻辑紧密相关的。

抽象产品(Abstract Product)角色:担任这个角色的类是工厂方法模式所创建的对象的父类,或它们共同拥有的接口。

具体产品(Concrete Product)角色:抽象工厂模式所创建的任何产品对象都是某一个具体产品类的实例。这是客户端最终需要的东西,其内部一定充满了应用系统的商业逻辑。


当每个抽象产品都有多于一个的具体子类的时候,工厂角色怎么知道实例化哪一个子类呢?比如每个抽象产品 [1]  角色都有两个具体产品。抽象工厂模式提供两个具体工厂角色,分别对应于这两个具体产品角色,每一个具体工厂角色只负责某一个产品角色的实例化。每一个具体工厂类只负责创建抽象产品的某一个具体子类的实例。

工厂方法模式与抽象工厂模式十分相似,工厂方法模式针对的是一个产品等级结构;而抽象工厂模式针对的是多个产品等级结构。

类图:


实例代码:
abstract class ProductA
    {
        public abstract void produce();
    }

abstract class ProductB
    {
        public abstract void produce();
    }
    class ConcreteProductA1 : ProductA
    {
        public override void produce()
        {
            Console.WriteLine("生产A1"); 
        }
    }
    class ConcreteProductA2 : ProductA
    {
        public override void produce()
        {
            Console.WriteLine("生产A2");
        }
    }

    class ConcreteProductB1 : ProductB
    {
        public override void produce()
        {
            Console.WriteLine("生产B1");
        }
    }
    class ConcreteProductB2 : ProductB
    {
        public override void produce()
        {
            Console.WriteLine("生产B2");
        }
    }

    abstract class AbstractFactroy
    {
        public abstract ProductA createA();

        public abstract ProductB createB();
    }

    class ConcreteFactory1 : AbstractFactroy
    {
        public override ProductA createA()
        {
            return new ConcreteProductA1();
        }
        public override ProductB createB()
        {
            return new ConcreteProductB1();
        }
    }

    class ConcreteFactory2 : AbstractFactroy
    {

        public override ProductA createA()
        {
            return new ConcreteProductA2();
        }
        public override ProductB createB()
        {
            return new ConcreteProductB2();
        }


    }

    class Program
    {
        static void Main(string[] args)
        {
            AbstractFactroy AF = new ConcreteFactory1();

            ProductA pro = AF.createA();
            pro.produce();

            ProductB prob = AF.createB();
            prob.produce();
            Console.ReadLine();
        }
    }


在以下情况下应当考虑使用抽象工厂模式:

一个系统不应当依赖于产品类实例如何被创建、组合和表达的细节,这对于所有形态的工厂模式都是重要的。

这个系统有多于一个的产品族,而系统只消费其中某一产品族。

同属于同一个产品族的产品是在一起使用的,这一约束必须在系统的设计中体现出来。

系统提供一个产品类的库,所有的产品以同样的接口出现,从而使客户端不依赖于实现。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值