0

如果我不需要一个特殊的工厂类并且我想要一个具体的客户端来实例化正确的部分怎么办。客户端需要从该部分调用 Hello() 。其他地方的重点是使工厂方法成为特殊创建者类的方法。但在这里,它立即出现在客户端中。这仍然是工厂方法模式吗?如下所示使用它是否正确?

using System;

namespace ConsoleApplication1
{
    class Program
    {
        static void Main(string[] args)
        {
            AClient c1 = new ClientUsingPart1();
            c1.Foo();
            AClient c2 = new ClientUsingPart2();
            c2.Foo();
            Console.ReadKey();
        }
    }

    abstract class AClient
    {
        public AClient() { this.ipart = Create(); }

        public void Foo() { ipart.Hello(); }
        // many other methods
        // ...
        public abstract IPart Create();  // factory method
        IPart ipart;
    }

    class ClientUsingPart1 : AClient
    {
        public override IPart Create() { return new Part1(); }
    }

    class ClientUsingPart2 : AClient
    {
        public override IPart Create() { return new Part2(); }
    }

    interface IPart
    {
        void Hello();
    }

    class Part1 : IPart
    {
        public void Hello() { Console.WriteLine("hello from part1"); }
    }
    class Part2 : IPart
    {
        public void Hello() { Console.WriteLine("hello from part2"); }
    }

}
4

2 回答 2

0

根据您需要实现的具体目标,您可能应该使用一些 for 依赖注入和您选择的 IoC 容器;StructureMap、Autofac、Unit、Ninject、Castle Windsor 都非常受欢迎。一旦你的 IoC 容器构建了具体的类,它应该支持这样的语法

foreach (var client in Container.Resolve<IEnumerable<AClient>>())
{
    client.Create();
}

您可以在此处阅读有关如何使用 StructureMap 实现此目的的更多信息:抽象类是否像接口一样与 StructureMap 一起使用?

于 2012-07-21T11:28:19.207 回答
0

据此: 抽象工厂模式和工厂方法之间的差异 似乎我在原始帖子中发布的代码显示了工厂方法模式的有效使用。关键是——工厂方法只是类的一个方法——它也可能是创建对象的唯一客户端。

或者换一种说法:工厂方法不需要公开,不需要对外提供创建的对象。在我的示例中,应保护 Create() 方法。

于 2012-07-22T20:55:45.600 回答