简单工厂:
到底要实例化谁,将来是否会增加实例化的对象,这是很容易变化的地方,应该考虑使用一个单独的类来做这个创造实例的过程,就是工厂。
如果基于上述代码,需要增加一个求M的N次方的操作,那么需要改工厂方法,增加case,这就违背了开放-封闭原则。
于是工厂方法来了。
工厂模式:
定义一个用于创建对象的接口,让子类决定实例化哪一个类,工厂方法使一个类的实例化延迟到其子类中。
如果现在要求,每种运算都需要再增加一种结果,为取模后再进行相应的加减乘除的处理方法。
那么变为抽象工厂模式:提供一个创建一系列相关或者相互依赖对象的接口,而无需指定它们的具体的类。
如果现在还要增加其项目表等,我们就需要增加至少三个类IProject,SqlserverProject,AccessProject。
还需要IFactory,SqlserverFactory,AccessFactory进行更改。
编程是门艺术,这样大量改动,显然非常丑陋。
想对抽象工厂进行改进:利用简单工厂。去除三个Factory类,直接利用简单工厂类:
其实,可以还可以进一步利用反射,读取配置文件,然后字符串传入DataAccess,运行时生成类实例。