php設(shè)計(jì)模式之迭代器模式實(shí)例分析【星際爭(zhēng)霸游戲案例】
本文實(shí)例講述了php設(shè)計(jì)模式之迭代器模式。分享給大家供大家參考,具體如下:
星際的任務(wù)關(guān)一般會(huì)有這樣的設(shè)定:一開(kāi)始電腦的農(nóng)民不采礦,如果戰(zhàn)斗打響,或者玩家造出第一個(gè)兵,電腦的農(nóng)民開(kāi)始采礦。
我們自然會(huì)想到把電腦的農(nóng)民放到一個(gè)數(shù)組,然后一旦玩家造兵,或者戰(zhàn)斗打響,把這個(gè)數(shù)組循環(huán),讓里面的農(nóng)民采礦。
但問(wèn)題出來(lái)了,由于每個(gè)任務(wù)的設(shè)定會(huì)有所不同,我們總希望任務(wù)的開(kāi)發(fā)比較方便,而且容易修改(一旦發(fā)現(xiàn)bug)。
何況有些任務(wù)不是農(nóng)民采礦,而是電腦出兵攻擊玩家。
那么過(guò)多的固定細(xì)節(jié)(用數(shù)組存放)以及依賴(lài)細(xì)節(jié)(對(duì)數(shù)組循環(huán)),將使得代碼的關(guān)聯(lián)性變得很高。
待解決的問(wèn)題:把循環(huán)處理的事務(wù)變的抽象。
思路:關(guān)鍵是對(duì)農(nóng)民的循環(huán),用數(shù)組處理只是一種方式,我們考慮抽象的數(shù)組,而不是具體的數(shù)組。
迭代器(Iterator)模式示例:
<?php //聚集接口,意思是所有電腦的農(nóng)民都聚集在這個(gè)類(lèi)里面 interface IAggregate { //讓具體的聚集類(lèi)實(shí)現(xiàn)的,獲取使用的迭代器的方法 public function createIterator(); } //具體的聚集類(lèi) class ConcreteAggregate implements IAggregate { //存放農(nóng)民的數(shù)組,注意可以不用數(shù)組來(lái)處理,看完所有的代碼就知道了 public $workers; //增加元素的方法,這里元素就是農(nóng)民 public function addElement($element) { $this->workers[] = $element; } //獲取元素的方法 public function getAt($index) { return $this->workers[$index]; } //獲取元素的數(shù)量的方法 public function getLength() { return count($this->workers); } //獲取迭代器的方法 public function createIterator() { return new ConcreteIterator($this); } } //迭代器接口,注意php5有個(gè)內(nèi)置的接口叫Iterator,所以這里我們改成IIterator interface IIterator { //是否元素循環(huán)完畢 public function hasNext(); //返回下一個(gè)元素,并將指針加1 public function next(); } //具體的迭代器類(lèi) class ConcreteIterator implements IIterator { //要迭代的集合 public $collection; //指針 public $index; //構(gòu)造函數(shù),確定迭代的集合,并將指針置零 public function __construct($collection) { $this->collection = $collection; $this->index = 0; } //是否元素循環(huán)完畢 public function hasNext() { if($this->index < $this->collection->getLength()) { return true; } else { return false; } } //返回下一個(gè)元素,并將指針加1 public function next() { $element = $this->collection->getAt($this->index); $this->index++; return $element; } } //初始化電腦的農(nóng)民的聚集對(duì)象 $farmerAggregate = new ConcreteAggregate(); //添加農(nóng)民,這里簡(jiǎn)單的用字符串表示 $farmerAggregate->addElement('SVC1'); $farmerAggregate->addElement('SVC2'); //獲取迭代器 $iterator = $farmerAggregate->createIterator(); //將農(nóng)民聚集對(duì)象循環(huán) while ($iterator->hasNext()) { //獲取下一個(gè)農(nóng)民 $element = $iterator->next(); //我們簡(jiǎn)單的輸出 echo $element; } ?>
用途總結(jié):迭代器模式建立了類(lèi)似數(shù)組的形式,從上面的代碼可以看到,如果要修改循環(huán)的處理,或者修改被循環(huán)的集合,都不必修改其它相關(guān)的代碼。
實(shí)現(xiàn)總結(jié):需要一個(gè)管理聚集的類(lèi),比如上面的ConcreteAggregate。另外需要迭代器類(lèi),比如上面的ConcreteIterator。然后把所有的操作,比如添加元素,獲取下一個(gè)元素,指針之類(lèi)的數(shù)組方面的操作抽象出來(lái),這樣其它的代碼只要使用方法,比如getLength(),而不是細(xì)節(jié)化的count()函數(shù),這樣即使不用數(shù)組存放農(nóng)民,也不需要改動(dòng)聚集類(lèi)以外的代碼。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語(yǔ)法入門(mén)教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP根據(jù)session與cookie用戶(hù)登錄狀態(tài)操作類(lèi)的代碼
這篇文章主要介紹了PHP根據(jù)session與cookie用戶(hù)登錄狀態(tài)操作類(lèi)的相關(guān)資料,非常具有參考借鑒價(jià)值,需要的朋友可以參考下2016-05-05關(guān)于DISCUZ不用通行證登陸得內(nèi)容介紹
DISCUZ是中國(guó)最常用的論壇,雖然他本身有通行證給大家連接,但實(shí)際上用戶(hù)的統(tǒng)一還是很不好,經(jīng)常要建立兩個(gè)用戶(hù)表,第一不利于注冊(cè)和管理,第二浪費(fèi)數(shù)據(jù)庫(kù)。2008-10-10php中使用$_REQUEST需要注意的一個(gè)問(wèn)題
本篇文章介紹了,php中使用$_REQUEST需要注意的一個(gè)問(wèn)題,需要的朋友參考下2013-05-05PHP采集類(lèi)snoopy詳細(xì)介紹(snoopy使用教程)
這篇文章主要介紹了PHP采集類(lèi)snoopy詳細(xì)介紹,PHP采集類(lèi)snoopy的詳細(xì)使用教程,需要的朋友可以參考下2014-06-06Laravel框架中VerifyCsrfToken報(bào)錯(cuò)問(wèn)題的解決
這篇文章主要給大家介紹了關(guān)于Laravel框架中VerifyCsrfToken報(bào)錯(cuò)問(wèn)題的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí),需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08