工厂办法模式
- 定义:定义一个创建对象的接口,但让实现这个接口的类来决定实例化哪个类。工厂办法让类的实例化推延到子类中进行。
- 类型:创立型
实用场景:
- 创建对象须要大量反复的代码
- 客户端(应用层)不依赖于产品类实例如何被创立、实现等细节
- 一个类通过其子类来指定创立哪个对象
长处:
- 用户只须要关怀所需产品对应的工厂,毋庸关怀创立细节
- 退出新产品合乎开闭准则,进步可扩展性
毛病:
- 类的个数容易过多,减少复杂度
- 减少了零碎的抽象性和了解难度
代码示例
实体类:
public abstract class Video { public abstract void produce();}
public class JavaVideo extends Video { @Override public void produce() { System.out.println("录制Java视频"); }}
public class PythonVideo extends Video { @Override public void produce() { System.out.println("录制Python视频"); }}
public class FEVideo extends Video{ @Override public void produce() { System.out.println("录制FE视频"); }}
工厂类:
public abstract class VideoFactory { public abstract Video getVideo();}
public class JavaVideoFactory extends VideoFactory{ @Override public Video getVideo() { return new JavaVideo(); }}
public class PythonVideoFactory extends VideoFactory{ @Override public Video getVideo() { return new PythonVideo(); }}
public class FEVideoFactory extends VideoFactory{ @Override public Video getVideo() { return new FEVideo(); }}
测试类:
public class Test { public static void main(String[] args) { VideoFactory javaVideoFactory = new JavaVideoFactory();// VideoFactory pythonVideoFactory = new PythonVideoFactory();// VideoFactory feVideoFactory = new FEVideoFactory(); Video video = javaVideoFactory.getVideo(); video.produce(); }}
XXXVideo、XXXVideoFactory 均为可扩大,减少或删除相应的局部不会影响已存在的其余局部的代码实现、或残余的局部的代码实现。
利用场景
JDK:
Collection(Iterator)
- Collection - VideoFactroy
- ArrayList - JavaVideoFactroy
- Iterator - Video
- Itr - JavaVideo
- URLStreamHandlerFactory
- Loggerfactory