模式的定义与特点
抽象工厂(AbstractFactory)模式的定义:是一种为访问类提供一个创建一组相关或相互依赖对象的接口,且访问类无须指定所要产品的具体类就能得到同族的不同等级的产品的模式结构。抽象工厂模式是工厂方法模式的升级版本,工厂方法模式只生产一个等级的产品,而抽象工厂模式可生产多个等级的产品。
使用抽象工厂模式一般要满足以下条件:
- 系统中有多个产品族,每个具体工厂创建同一族但属于不同等级结构的产品。
- 系统一次只可能消费其中某一族产品,即同族的产品一起使用。
抽象工厂模式除了具有工厂方法模式的优点外,其他主要优点如下。
- 可以在类的内部对产品族中相关联的多等级产品共同管理,而不必专门引入多个新的类来进行管理。
- 当增加一个新的产品族时不需要修改原代码,满足开闭原则。
其缺点是:当产品族中需要增加一个新的产品时,所有的工厂类都需要进行修改。
模式的结构与实现
抽象工厂模式同工厂方法模式一样,也是由抽象工厂、具体工厂、抽象产品和具体产品等 4 个要素构成,但抽象工厂中方法个数不同,抽象产品的个数也不同。
抽象工厂模式的主要角色如下。
- 抽象工厂(Abstract Factory):提供了创建产品的接口,它包含多个创建产品的方法 newProduct(),可以创建多个不同等级的产品。
- 具体工厂(Concrete Factory):主要是实现抽象工厂中的多个抽象方法,完成具体产品的创建。
- 抽象产品(Product):定义了产品的规范,描述了产品的主要特性和功能,抽象工厂模式有多个抽象产品。
- 具体产品(ConcreteProduct):实现了抽象产品角色所定义的接口,由具体工厂来创建,它 同具体工厂之间是多对一的关系。
代码讲解
抽象产品(Product):定义了产品的规范,描述了产品的主要特性和功能,抽象工厂模式有多个抽象产品。
//手机产品接口
public interface IphoneProduct {
//手机开机
void open();
//手机关机
void shutdown();
//手机发短信
void sendMsg();
}
//路由器产品接口
public interface IRouterProduct {
//路由器开机
void open();
//路由器关机
void shutdown();
//路由器打开wifi
void wifi();
}
具体产品(ConcreteProduct):实现了抽象产品角色所定义的接口,由具体工厂来创建,它 同具体工厂之间是多对一的关系。
public class XiaomiPhone implements IphoneProduct {
@Override
public void open() {
System.out.println("小米手机开机");
}
@Override
public void shutdown() {
System.out.println("小米手机关机");
}
@Override
public void sendMsg() {
System.out.println("小米手机发短信");
}
}
public class XiaomiRouter implements IRouterProduct {
@Override
public void open() {
System.out.println("小米路由器开机");
}
@Override
public void shutdown() {
System.out.println("小米路由器关机");
}
@Override
public void wifi() {
System.out.println("小米路由器打开 wifi");
}
}
抽象工厂(Abstract Factory):提供了创建产品的接口,它包含多个创建产品的方法 newProduct(),可以创建多个不同等级的产品。
//抽象工厂接口
public interface Factory {
//生产手机
IphoneProduct phoneProduct();
//生产路由器
IRouterProduct routerProduct();
}
具体工厂(Concrete Factory):主要是实现抽象工厂中的多个抽象方法,完成具体产品的创建。
public class XiaomiFactory implements Factory {
@Override
public IphoneProduct phoneProduct() {
return new XiaomiPhone();
}
@Override
public IRouterProduct routerProduct() {
return new HuaweiRouter();
}
}
个人理解就是,抽象工厂模式将具体产品进行了抽象,同时也将工厂进行了抽象。无处不在的在进行面向接口编程,当需要生产具体商品的时候,先要生成具体的工厂,然后再生产具体的商品。
增加一个新的产品族是不要改动原有代码的,只需要增加对应的产品和工厂并实现相关的接口就可以了。当产品族中需要增加一个新的产品时,所有的工厂类都需要进行修改。