一、简单工厂模式
又称为静态工厂方法(Static Factory Method)模式,它属于类创建型模式。在简单工厂模式中,可以根据参数的不同返回不同类的实例。简单工厂模式专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。
角色:
Factory类:负责创建具体产品的实例
Product类:抽象产品类,定义产品子类的公共接口
ConcreteProduct 类:具体产品类,实现Product父类的接口功能,也可添加自定义的功能
UML图:
PHP实现:
/**
* ==================简单工厂模式
*/
/**
* 负责创建具体产品的实例
*/
class Factory
{
public static function createProduct($name)
{
$object = null;
switch($name)
{
case 'ProductA':
$object = new ProductA();
break;
case 'ProductB':
$object = new ProductB();
break;
default:
}
return $object;
}
}
/**
* 抽象产品类,定义产品子类的公共接口
*/
abstract class Product
{
public function __construct()
{
echo '我是抽象产品类
';
}
}
/**
* 具体产品类,实现Product父类的接口功能,也可添加自定义的功能
*/
class ProductA
{
public function __construct()
{
echo '我是具体产品类A
';
}
}
/**
* 具体产品类,实现Product父类的接口功能,也可添加自定义的功能
*/
class ProductB
{
public function __construct()
{
echo '我是具体产品类B
';
}
}
$productA = Factory::createProduct('ProductA');
$productB = Factory::createProduct('ProductB');
简单工厂模式最大的优点在于实现对象的创建和对象的使用分离,将对象的创建交给专门的工厂类负责,但是其最大的缺点在于工厂类不够灵活,增加新的具体产品需要修改工厂类的判断逻辑代码,而且产品较多时,工厂方法代码将会非常复杂。
二、工厂方法模式
通过定义一个抽象的核心工厂类,并定义创建产品对象的接口,创建具体产品实例的工作延迟到其工厂子类去完成。这样做的好处是核心类只关注工厂类的接口定义,而具体的产品实例交给具体的工厂子类去创建。当系统需要新增一个产品,无需修改现有系统代码,只需要添加一个具体产品类和其对应的工厂子类,是系统的扩展性变得很好,符合面向对象编程的开闭原则。
角色:
Product:抽象产品类
ConcreteProduct:具体产品类
Factory:抽象工厂类
ConcreteFactory:具体工厂类
UML图:
PHP实现:
/**
* ==================工厂方法模式
*/
/**
* 抽象工厂类
*/
abstract class Factory
{
public abstract static function createAnimal();
}
/**
* 具体工厂类CatFactory
*/
class CatFactory extends Factory
{
public static function createAnimal()
{
return new Cat();
}
}
/**
* 具体工厂类DogFactory
*/
class DogFactory extends Factory
{
public static function createAnimal()
{
return new Dog();
}
}
/**
* 接口Animal
*/
interface Animal
{
public function run();
public function say();
}
/**
* 具体Animal Cat
*/
class Cat implements Animal
{
public function run()
{
echo '我是猫会跑
';
}
public function say()
{
echo '我是猫会叫
';
}
}
/**
* 具体Animal Dog
*/
class Dog implements Animal
{
public function run()
{
echo '我是狗会跑
';
}
public function say()
{
echo '我是狗会叫
';
}
}
$cat = CatFactory::createAnimal();
$cat->run();
$cat->say();
$dog = DogFactory::createAnimal();
$dog->run();
$dog->say();
工厂方法模式是简单工厂模式的进一步抽象和推广。由于使用了面向对象的多态性,工厂方法模式保持了简单工厂模式的优点,而且克服了它的缺点。在工厂方法模式中,核心的工厂类不再负责所有产品的创建,而是将具体创建工作交给子类去做。这个核心类仅仅负责给出具体工厂必须实现的接口,而不负责产品类被实例化这种细节,这使得工厂方法模式可以允许系统在不修改工厂角色的情况下引进新产品。
三、抽象工厂模式
提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。抽象工厂模式又称为Kit模式,属于对象创建型模式。
此模式是对工厂方法模式的进一步扩展。在工厂方法模式中,一个具体的工厂负责生产一类具体的产品,即一对一的关系,但是,如果需要一个具体的工厂生产多种产品对象,那么就需要用到抽象工厂模式了。
产品等级结构:产品等级结构即产品的继承结构,如一个抽象类是电视机,其子类有海尔电视机、海信电视机、TCL电视机,则抽象电视机与具体品牌的电视机之间构成了一个产品等级结构,抽象电视机是父类,而具体品牌的电视机是其子类。
产品族 :在抽象工厂模式中,产品族是指由同一个工厂生产的,位于不同产品等级结构中的一组产品,如海尔电器工厂生产的海尔电视机、海尔电冰箱,海尔电视机位于电视机产品等级结构中,海尔电冰箱位于电冰箱产品等级结构中。
角色:
抽象工厂(AbstractFactory):担任这个角色的是抽象工厂模式的核心,是与应用系统的商业逻辑无关的。
具体工厂(Factory):这个角色直接在客户端的调用下创建产品的实例,这个角色含有选择合适的产品对象的逻辑,而这个逻辑是与应用系统商业逻辑紧密相关的。
抽象产品(AbstractProduct):担任这个角色的类是抽象工厂模式所创建的对象的父类,或它们共同拥有的接口
具体产品(Product):抽象工厂模式所创建的任何产品对象都是一个具体的产品类的实例。
UML图:
PHP实现:
/**
* ==================抽象工厂模式(Kit模式)
*/
/**
* 抽象工厂
*/
abstract class Factory
{
public abstract static function createPC();
public abstract static function createTV();
}
/**
* 具体工厂
*/
class ProductFactory extends Factory
{
public static function createPC()
{
return new LenovePC();
}
public static function createTV()
{
return new HaierTV();
}
}
/**
* 抽象产品
*/
interface PC
{
public function work();
public function play();
}
interface TV
{
public function open();
public function watch();
}
/**
* 具体产品
*/
class LenovePC implements PC
{
public function work()
{
echo '我是联想电脑
';
}
public function play()
{
echo '联想电脑可以玩游戏
';
}
}
class HaierTV implements TV
{
public function open()
{
echo '打开海尔电视机
';
}
public function watch()
{
echo '观看电视
';
}
}
$lenovePc = ProductFactory::createPC();
$lenovePc->work();
$lenovePc->play();
$haierTv = ProductFactory::createTV();
$haierTv->open();
$haierTv->watch();