生成器模式-创建型设计模式 [PHP]

目的:生成器的目的是将复杂对象的创建过程(流程)进行抽象,生成器表现为接口的形式。

如果对象有复杂的继承树,理论上创建对象的生成器也同样具有复杂的继承树。

传进来一个生成器, 我调用这个生成器来生成我所需要的汽车,这就是生成器模式的核心.这个生成器Builder是个接口,把复杂对象的创建过程进行抽象

class Director\n{\n    public function build(Builder $builder): Vehicle\n    {\n        $builder->createVehicle();\n        $builder->addDoors();\n        $builder->addEngine();\n        $builder->addWheel();\n        return $builder->getVehicle();\n    }\n}

这就是生成器这个接口

 

interface Builder\n{\n    public function createVehicle();\n    public function addWheel();\n    public function addEngine();\n    public function addDoors();\n    public function getVehicle(): Vehicle;\n}

有两个具体的实现类 CarBuilder TruckBuilder 分别生成汽车和卡车

 

class TruckBuilder implements Builder\n{\n    private Truck $truck;\n    public function addDoors(){\n    }\n    public function addEngine(){\n    }\n    public function addWheel(){\n    }\n\n    public function createVehicle(){\n    }\n\n    public function getVehicle(): Vehicle{\n    }\n}

使用的时候,先创建builder,把builder通过参数传递进去

$truckBuilder = new TruckBuilder();\n$newVehicle = (new Director())->build($truckBuilder);

组合模式-结构型设计模式 [PHP]

 

以单个对象的方式来对待一组对象有一个接口类,有一个需实现的方法,其他所有类都实现它,在一个组合类的实现方法中循环调用另外其他类的方法

有一个公共的接口类

interface Renderable\n{\n    public function render(): string;\n}

组合类,也实现了接口

class Form implements Renderable\n{\n    private array $elements;\n    public function render(): string\n    {\n        //组合类里面循环调用其他类的同名方法\n        foreach ($this->elements as $element) {\n            $element->render();\n        }\n    }\n    public function addElement(Renderable $element)\n    {\n        $this->elements[] = $element;\n    }\n}

子项类,也实现了接口

class InputElement implements Renderable\n{\n    public function render(): string\n    {\n    }\n}\nclass TextElement implements Renderable\n{\n    public function render(): string\n    {\n    }\n}

使用的时候,像使用单一类一样使用组合类

$form = new Form();\n$form->addElement(new TextElement());\n$form->addElement(new InputElement());\n$form->render();

桥接模式-结构型设计模式 [PHP]

解耦一个对象的实现与抽象,这样两者可以独立地变化。\n对一个功能进行拆分成两个具体对象,通过构造函数或者方法传递桥接起来两个对象

通过传递另外对象来实现功能,本身保留抽象方法给子类去独立实现

abstract class Service\n{\n    protected Formatter $implementation;\n    public function __construct(Formatter $printer)\n    {\n        $this->implementation = $printer;\n    }\n\n    public function setImplementation(Formatter $printer)\n    {\n        $this->implementation = $printer;\n    }\n    abstract public function get(): string;\n}

两个子类实现同一个方法,不同的功能

class HelloWorldService extends Service\n{\n    public function get(): string\n    {\n        return $this->implementation->format(\'Hello World\');\n    }\n}\nclass PingService extends Service\n{\n    public function get(): string\n    {\n        return $this->implementation->format(\'pong\');\n    }\n}

具体的功能实现由另外的独立类来做,这样两个就可以独立变化了

interface Formatter\n{\n    public function format(string $text): string;\n}\nclass PlainTextFormatter implements Formatter\n{\n    public function format(string $text): string\n    {\n        return $text;\n    }\n}

使用,现在它本身可以通过子类独立变化,具体功能类可以传递进来,两者也是各自独立

$service = new HelloWorldService(new PlainTextFormatter());\n$service->get();