2020-11-21

工厂方法模式
工厂方法模式可以解决简单工厂模式中存在的问题:–简单工厂模式系统难以扩展,一旦添加新产品就不得不修改简单工厂方法,这样就会造成简单工厂的实现逻辑过于复杂。
一、工厂方法模式的实现
工厂方法模式之所以可以解决简单工厂模式存在的问题,是因为它的实现把具体产品的创建推迟到子类中,此时工厂类不在负责所有产品的创建,而只是给出具体工厂必须实现的接口,这样工厂方法模式就可以允许系统不修改工厂类逻辑的情况下来添加新产品,这样也就克服了简单工厂模式中的缺点。下面看下工厂模式的具体实现代码:
namespace 设计模式之工厂方法模式
{
///
/// 菜抽象类
///
public abstract class Food
{
// 输出点了什么菜
public abstract void Print();
}

/// <summary>
/// 西红柿炒鸡蛋这道菜
/// </summary>
public class TomatoScrambledEggs : Food
{
    public override void Print()
    {
        Console.WriteLine("西红柿炒蛋好了!");
    }
}

/// <summary>
/// 土豆肉丝这道菜
/// </summary>
public class ShreddedPorkWithPotatoes : Food
{
    public override void Print()
    {
        Console.WriteLine("土豆肉丝好了");
    }
}

/// <summary>
/// 抽象工厂类
/// </summary>
public abstract class Creator
{
    // 工厂方法
    public abstract Food CreateFoddFactory();
}

/// <summary>
/// 西红柿炒蛋工厂类
/// </summary>
public class TomatoScrambledEggsFactory:Creator
{
    /// <summary>
    /// 负责创建西红柿炒蛋这道菜
    /// </summary>
    /// <returns></returns>
    public override Food CreateFoddFactory()
    {
        return new TomatoScrambledEggs();
    }
}

/// <summary>
/// 土豆肉丝工厂类
/// </summary>
public class ShreddedPorkWithPotatoesFactory:Creator
{
    /// <summary>
    /// 负责创建土豆肉丝这道菜
    /// </summary>
    /// <returns></returns>
    public override Food CreateFoddFactory()
    {
        return new ShreddedPorkWithPotatoes();
    }
}

/// <summary>
/// 客户端调用
/// </summary>
class Client
{
    static void Main(string[] args)
    {
        // 初始化做菜的两个工厂()
        Creator shreddedPorkWithPotatoesFactory = new ShreddedPorkWithPotatoesFactory();
        Creator tomatoScrambledEggsFactory = new TomatoScrambledEggsFactory();

        // 开始做西红柿炒蛋
        Food tomatoScrambleEggs = tomatoScrambledEggsFactory.CreateFoddFactory();
        tomatoScrambleEggs.Print();

        //开始做土豆肉丝
        Food shreddedPorkWithPotatoes = shreddedPorkWithPotatoesFactory.CreateFoddFactory();
        shreddedPorkWithPotatoes.Print();

        Console.Read();
    }
}  

}
使用工厂方法实现的系统,如果系统需要添加新产品时,我们可以利用多态性来完成系统的扩展,对于抽象工厂类和具体工厂中的代码都不需要做任何改动。例如,现在还想点一个“肉末茄子”,
此时我们只需要定义一个肉末茄子具体工厂类和肉末茄子类就可以。而不用像简单工厂模式中那样去修改工厂类中的实现。
//肉末茄子这道菜
public class MincedMeatEggplant:Food
{
//重写抽象类中的方法
public override void Print()
{
Console.WriteLine(“肉末茄子好了”);
}
}

//肉末茄子工厂类,负责创建肉末茄子这道菜
public class MincedMeatEggplantFactory:Creator
{
//负责创建肉末茄子这道菜
public override Food CreateFoodFactory()
{
return new MincedMeatEggplant();
}
}

//客户端调用
class Client
{
static void Main(string[] args)
{
//如果客户又想点肉末茄子了
//再另外初始化一个肉末茄子工厂
Creator minceMeatEggplantFactory = new MincedMeatEggplantFactory();

	//利用肉末茄子工厂来创建肉末茄子这道菜
	Food minceMeatEggplant = minceMeatEggplantFactor.CreateFoodFactory();
	minceMeatEggplant.Print();

	Console.Read();
}

}

工厂方法模式通过面向对象编程中的多态性来将对象的创建延迟到具体工厂中,从而解决了简单工厂模式中存在的问题,也很好地符合了开放封闭原则(即对扩展开发,对修改封闭)。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值