本文共 1649 字,大约阅读时间需要 5 分钟。
实现了创建者和调用者的分离
–实例化对象,用工厂方法代替new操作。
–将选择实现类、创建对象统一管理和控制。从而将调用者跟我们的实现类解耦。用来生产同一等级结构中的任意产品。(对于增加新的产品,需要修改已有代码)
在一个工厂类中生产任意产品用来生产同一等级结构中的固定产品。(支持增加任意产品)
不用于简单工厂模式,每个产品对应一个工厂类简单工厂模式:
先创建一个接口Car:public interface Car { void run();}
编写两个实现类:
Audi:public class Audi implements Car { @Override public void run() { System.out.println("奥迪再跑!"); }}
Byd:
public class Byd implements Car { @Override public void run() { System.out.println("比亚迪再跑!"); }}
工厂类:
public class CarFactory { public static Car createCar(String type){ if("奥迪".equals(type)){ return new Audi(); }else if("比亚迪".equals(type)){ return new Byd(); }else{ return null; } } }
测试:
public class Client02 { //调用者 public static void main(String[] args) { Car c1 =CarFactory.createCar("奥迪"); Car c2 = CarFactory.createCar("比亚迪"); c1.run(); c2.run(); }}
工厂方法模式:
接口Car,实现类Audi/Benz同上设计工厂类的接口:
public interface CarFactory { Car createCar();}
Audi的工厂类:
public class AudiFactory implements CarFactory { @Override public Car createCar() { return new Audi(); }}
Benz的工厂类
public class BenzFactory implements CarFactory { @Override public Car createCar() { return new Benz(); }}
测试:
public class Client { public static void main(String[] args) { Car c1 = new AudiFactory().createCar(); Car c2 = new BenzFactory().createCar(); c1.run(); c2.run(); }}
–简单工厂模式(静态工厂模式)
•虽然某种程度不符合设计原则,但实际使用最多。–工厂方法模式
•不修改已有类的前提下,通过增加新的工厂类实现扩展。–抽象工厂模式
•不可以增加产品,可以增加产品族!–JDK中Calendar的getInstance方法
–JDBC中Connection对象的获取 –Hibernate中SessionFactory创建Session –spring中IOC容器创建管理bean对象 –XML解析时的DocumentBuilderFactory创建解析器对象 –反射中Class对象的newInstance()转载地址:http://snzfb.baihongyu.com/