温馨提示:查看本手记请先查看上一次发布的《工厂模式_简单工厂模式》
http://www.imooc.com/article/8661
定义了一个创建对象的抽象方法,由子类决定要实例化的类
工厂方法的模式将对象的实例化推迟到子类
优点
大牛:“小鸟,你又没有发现,使用简单工厂去设计四则运算表的时候,其实对于LowTableFactory
类来说是违背了开闭原则的。”
小鸟:“发现了,如果我要增加其它的算法表的类,那么同时我也要去修改LowTableFactory类,给其添加一个case。”
大牛:“说的不错,对于这个问题,你有什么好的解决思路呢?”
小鸟:“我的解决方法就是,使用工厂方法模式,以下就是我的代码(以加法表和乘法表为例
)”
抽象产品角色:AFourOperations
四则运算法则
public abstract class AFourOperations {
public abstract void operations();
}
具体产品角色1:AddOperations
加法表
public class AddOperations extends AFourOperations {
@Override
public void operations() {
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(String.format("%d+%d=%d\t", j, i, i + j));
}
System.out.println("");
}
}
}
具体产品角色2:MultiplicationOperations
乘法表
public class MultiplicationOperations extends AFourOperations {
@Override
public void operations() {
for (int i = 1; i <= 9; i++) {
for (int j = 1; j <= i; j++) {
System.out.print(String.format("%d*%d=%d\t", j, i, i * j));
}
System.out.println("");
}
}
}
抽象工厂角色:IFourOperationsFactory
工厂类
public abstract class AFourOperationsFactory {
public abstract AFourOperations createFourOperations();
}
具体工厂角色1:AddOperationsFactory
加法工厂
public class AddOperationsFactory extends AFourOperationsFactory {
@Override
public AFourOperations createFourOperations() {
return new AddOperations();
}
}
具体工厂角色2:MultiplicationOperationsFactory
乘法工厂
public class MultiplicationOperationsFactory extends AFourOperationsFactory {
@Override
public AFourOperations createFourOperations() {
return new MultiplicationOperations();
}
}
客户端调用
AFourOperationsFactory factory = new MultiplicationOperationsFactory();
AFourOperations aFourOperations = factory.createFourOperations();
aFourOperations.operations();
大牛:“嗯嗯,不错,结构很清晰!”
小鸟:“牛哥,我发现这个还不如简单工厂好用呢!这里每创建一个类,就得为其创建对应的工厂,感觉无形中增加了好多类啊!
”
大牛:“确实,这就是工厂方法模式和简单工厂的一个最大区别,工厂方法模式虽然增加了很多类,但它更符合开-闭原则,降低了客户端与后台的耦合度
”
2025 - 快车库 - 我的知识库 重庆启连科技有限公司 渝ICP备16002641号-10
企客连连 表单助手 企服开发 榜单123