思路:既然星际的画面由几个部分组成:地图(就是地形和矿产),建筑,部队。那么我们把他们看成是零件,组装起来就是最后的产品(整个画面)。
建造器(Builder)模式示例:
| 代码如下 | 复制代码 |
|
//规范制造各个零件的接口 interface Builder { //制造地图零件 public function buildMapPart(); //制造建筑零件 public function buildBuildingPart(); //制造部队零件 public function buildArmyPart(); //组装零件 public function getResult(); } //实际建造器类,比如初始化某个任务关 class ConcreteBuilder implements Builder { //制造地图零件 public function buildMapPart() { //根据任务的设定画上地图 echo '地图零件n'; } //制造建筑零件 public function buildBuildingPart() { //根据任务的设定画上建筑,包括玩家的和敌人的 echo '建筑零件n'; } //制造部队零件 public function buildArmyPart() { //根据任务的设定画上部队,包括玩家的和敌人的 echo '部队零件n'; } //组装零件 public function getResult() { //将所有的东西叠加和处理,形成初始化画面 echo '组装零件n'; } } //监督类,也就是控制绘制流程的类 class Director { //私有属性,确定使用的建造器 private $builder; //构造方法,参数为选定的建造器对象 public function __construct($builder) { //确定使用的建造器 $this->builder = $builder; } //负责建造流程的方法,调用建造器对象的方法,制造所有零件 public function buildeAllPart() { //制造地图零件 $this->builder->buildMapPart(); //制造建筑零件 $this->builder->buildBuildingPart(); //制造部队零件 $this->builder->buildArmyPart(); } } //假设根据任务关,初始化我们需要的实际建造器对象 $concreteBuilder = new ConcreteBuilder(); //初始化一个监督对象 $director = new Director($concreteBuilder); //制造所有零件 $director->buildeAllPart(); //最后让建造器组装零件,生成画面 $concreteBuilder->getResult(); ?> |
|
用途总结:建造器模式可以将流程和细节分离,各司其职。
实现总结:需要一个建造器接口或者抽象类,负责规范各个方法,比如上面的Builder。然后让实际的建造器类去实现所有的方法,比如上面的ConcreteBuilder。同时需要负责流程管理的监督类,比如上面的Director,负责调用建造器的各个零件制造方法。最后让建造器去组装所有的零件
g沙盒仇恨官方英文版(gorebox)
G沙盒仇恨英文原版是一款最近非常火热的沙盒模拟类游戏,在这里
迷你世界测试服最新版2024
迷你世界测试服2021最新版,即迷你世界的先遣服版本,用户能
闪耀暖暖最新版2024
闪耀暖暖手游这是非常好玩的换装手游,游戏内容丰富有趣,游戏环
杜拉拉升职记官方正版
杜拉拉升职记手游完美还原了经典同名电视剧中的故事剧情、以及各
银河战舰手机版
银河战舰满你所想宇宙战舰世界,茫茫宇宙资源是一切,你必须利用