本文實(shí)例講述了PHP注冊(cè)樹(shù)模式。分享給大家供大家參考,具體如下:
什么是注冊(cè)樹(shù)模式?
注冊(cè)樹(shù)模式當(dāng)然也叫注冊(cè)模式,注冊(cè)器模式。之所以我在這里矯情一下它的名稱,是因?yàn)槲腋杏X(jué)注冊(cè)樹(shù)這個(gè)名稱更容易讓人理解。像前兩篇一樣,我們這 篇依舊是從名字入手。注冊(cè)樹(shù)模式通過(guò)將對(duì)象實(shí)例注冊(cè)到一棵全局的對(duì)象樹(shù)上,需要的時(shí)候從對(duì)象樹(shù)上采摘的模式設(shè)計(jì)方法。 這讓我想起了小時(shí)候買糖葫蘆,賣糖葫蘆的將糖葫蘆插在一個(gè)大的桿子上,人們買的時(shí)候就取下來(lái)。不同的是,注冊(cè)樹(shù)模式摘下來(lái)還會(huì)有,能摘很多次,糖葫蘆摘一 次就沒(méi)了。。。
為什么要采用注冊(cè)樹(shù)模式?
單例模式解決的是如何在整個(gè)項(xiàng)目中創(chuàng)建唯一對(duì)象實(shí)例的問(wèn)題,工廠模式解決的是如何不通過(guò)new建立實(shí)例對(duì)象的方法。 那么注冊(cè)樹(shù)模式想解決什么問(wèn)題呢? 在考慮這個(gè)問(wèn)題前,我們還是有必要考慮下前兩種模式目前面臨的局限。 首先,單例模式創(chuàng)建唯一對(duì)象的過(guò)程本身還有一種判斷,即判斷對(duì)象是否存在。存在則返回對(duì)象,不存在則創(chuàng)建對(duì)象并返回。 每次創(chuàng)建實(shí)例對(duì)象都要存在這么一層判斷。 工廠模式更多考慮的是擴(kuò)展維護(hù)的問(wèn)題。 總的來(lái)說(shuō),單例模式和工廠模式可以產(chǎn)生更加合理的對(duì)象。怎么方便調(diào)用這些對(duì)象呢?而且在項(xiàng)目?jī)?nèi)如此建立的對(duì)象好像散兵游勇一樣,不便統(tǒng)籌管理安排啊。因 而,注冊(cè)樹(shù)模式應(yīng)運(yùn)而生。不管你是通過(guò)單例模式還是工廠模式還是二者結(jié)合生成的對(duì)象,都統(tǒng)統(tǒng)給我“插到”注冊(cè)樹(shù)上。我用某個(gè)對(duì)象的時(shí)候,直接從注冊(cè)樹(shù)上取 一下就好。這和我們使用全局變量一樣的方便實(shí)用。 而且注冊(cè)樹(shù)模式還為其他模式提供了一種非常好的想法。
如何實(shí)現(xiàn)注冊(cè)樹(shù)?
通過(guò)上述的描述,我們似乎很容易就找到了解決方法。首先我們需要一個(gè)作為注冊(cè)樹(shù)的類,這毋庸置疑。所有的對(duì)象“插入”到注冊(cè)樹(shù)上。這個(gè)注冊(cè)樹(shù)應(yīng) 該由一個(gè)靜態(tài)變量來(lái)充當(dāng)。而且這個(gè)注冊(cè)樹(shù)應(yīng)該是一個(gè)二維數(shù)組。這個(gè)類應(yīng)該有一個(gè)插入對(duì)象實(shí)例的方法(set()
),當(dāng)讓相對(duì)應(yīng)的就應(yīng)該有一個(gè)撤銷對(duì)象實(shí)例 的方法(_unset()
)。當(dāng)然最重要的是還需要有一個(gè)讀取對(duì)象的方法(get()
)。擁有這些,我們就可以愉快地完成注冊(cè)樹(shù)模式啦~~~
下面讓三種模式做個(gè)小小的結(jié)合。單純創(chuàng)建一個(gè)實(shí)例對(duì)象遠(yuǎn)遠(yuǎn)沒(méi)有這么復(fù)雜,但運(yùn)用于大型項(xiàng)目的話,便利性便不言而喻了。
?php //創(chuàng)建單例 class Single{ public $hash; static protected $ins=null; final protected function __construct(){ $this->hash=rand(1,9999); } static public function getInstance(){ if (self::$ins instanceof self) { return self::$ins; } self::$ins=new self(); return self::$ins; } } //工廠模式 class RandFactory{ public static function factory(){ return Single::getInstance(); } } //注冊(cè)樹(shù) class Register{ protected static $objects; public static function set($alias,$object){ self::$objects[$alias]=$object; } public static function get($alias){ return self::$objects[$alias]; } public static function _unset($alias){ unset(self::$objects[$alias]); } } Register::set('rand',RandFactory::factory()); $object=Register::get('rand'); print_r($object);
至此,三種模式設(shè)計(jì)介紹完畢。各種模式設(shè)計(jì)本身就會(huì)相輔相成,往后介紹其他模式的時(shí)候,多多少少會(huì)用到一種或多種其他設(shè)計(jì)模式。
一種模式不懂不要緊,相信編程的深入,定會(huì)產(chǎn)生恍然大悟的驚喜感 ,愿諸君與我共進(jìn)步。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP基本語(yǔ)法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
標(biāo)簽:太原 南昌 南京 濱州 株洲 曲靖 白酒營(yíng)銷 興安盟
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP設(shè)計(jì)模式之注冊(cè)樹(shù)模式分析》,本文關(guān)鍵詞 PHP,設(shè)計(jì)模式,之,注冊(cè),樹(shù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。