PHP SPL標(biāo)準(zhǔn)庫之雙向鏈表

簡介

SPL是用于解決典型問題(standard problems)的一組接口與類的集合,包括數(shù)據(jù)結(jié)構(gòu)、迭代器钮科、接口、異常等婆赠。鏈表是一種物理存儲單元上非連續(xù)绵脯、非順序的存儲結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過鏈表中的指針鏈接次序?qū)崿F(xiàn)的。鏈表由一系列結(jié)點(鏈表中每一個元素稱為結(jié)點)組成蛆挫,結(jié)點可以在運行時動態(tài)生成赃承。每個結(jié)點包括兩個部分:一個是存儲數(shù)據(jù)元素的數(shù)據(jù)域,另一個是存儲下一個結(jié)點地址的指針域璃吧。 相比于線性表順序結(jié)構(gòu)楣导,操作復(fù)雜。由于不必須按順序存儲畜挨,鏈表在插入的時候可以達(dá)到O(1)的復(fù)雜度筒繁,比另一種線性表順序表快得多,但是查找一個節(jié)點或者訪問特定編號的節(jié)點則需要O(n)的時間巴元,而線性表和順序表相應(yīng)的時間復(fù)雜度分別是O(logn)和O(1)毡咏。
雙向鏈表在PHP SPL里面有2種實現(xiàn),一種是棧逮刨,特性是FIFO(first input first output)呕缭,先進(jìn)先出,就像咱排隊上地鐵一樣修己,排在前面的先上地鐵恢总;還有一種是隊列。特性是LIFO(last input first output)睬愤,后進(jìn)先出片仿,這個看上去有點不合常理,在日常生活中的例子就是往箱子里面放東西尤辱,你肯定要把后面放進(jìn)去的東西先拿出來才能拿最底下的東西砂豌。在SPL里面,全部提供了實現(xiàn)光督,這個比你自己實現(xiàn)效率高多了阳距。

1.類摘要

SplDoublyLinkedList implements Iterator , ArrayAccess , Countable {
    /* 方法 */
    public __construct ( void )
    public void add ( mixed $index , mixed $newval ) #添加一個元素
    public mixed bottom ( void ) 
    public int count ( void ) 
    public mixed current ( void ) # 返回當(dāng)前指針指向的元素
    public int getIteratorMode ( void ) # 返回迭代模式
    public bool isEmpty ( void )
    public mixed key ( void )
    public void next ( void ) # 移動指針到下一個元素
    public bool offsetExists ( mixed $index )
    public mixed offsetGet ( mixed $index )
    public void offsetSet ( mixed $index , mixed $newval )
    public void offsetUnset ( mixed $index )
    public mixed pop ( void ) # 彈出一個元素,從隊列頭出列
    public void prev ( void )
    public void push ( mixed $value ) # 增加一個元素结借,從隊列頭入列
    public void rewind ( void ) # 初始化隊列
    public string serialize ( void )
    public void setIteratorMode ( int $mode ) # 設(shè)置迭代模式筐摘,棧或者隊列
    public mixed shift ( void ) # 彈出一個元素船老,從隊列尾出列
    public mixed top ( void )
    public void unserialize ( string $serialized )
    public void unshift ( mixed $value ) # 增加一個元素咖熟,從隊列尾入列
    public bool valid ( void )
}

2.實例

<?php

$dll = new SplDoublyLinkedList();
# 添加元素
$dll->add(0, 'a');
$dll->add(1, 'b');
$dll->add(2, 'c');
$dll->add(3, 'd');
# 遍歷鏈表,這個迭代模式有4種,源碼里面定義的內(nèi)容
#        const IT_MODE_LIFO = 2;  后進(jìn)先出努隙,其實就是棧
#        const IT_MODE_FIFO = 0;  先進(jìn)先出球恤,其實就是隊列
#        const IT_MODE_DELETE = 1; 刪除元素
#        const IT_MODE_KEEP = 0; 保持原來的順序
$dll->setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO);
for ($dll->rewind(); $dll->valid(); $dll->next()) {
    var_dump($dll->current()) . "\n";
}

3.總結(jié)

平時寫業(yè)務(wù)代碼很少用到這些東西辜昵,不過很多PHP框架其實都用到這些了荸镊,一些庫的底層也用到了,畢竟數(shù)據(jù)結(jié)構(gòu)都是通用的,了解一下還是不錯滴

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末躬存,一起剝皮案震驚了整個濱河市张惹,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌岭洲,老刑警劉巖宛逗,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異盾剩,居然都是意外死亡雷激,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進(jìn)店門告私,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屎暇,“玉大人,你說我怎么就攤上這事驻粟「浚” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵蜀撑,是天一觀的道長挤巡。 經(jīng)常有香客問我,道長酷麦,這世上最難降的妖魔是什么矿卑? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮贴铜,結(jié)果婚禮上粪摘,老公的妹妹穿的比我還像新娘。我一直安慰自己绍坝,他們只是感情好徘意,可當(dāng)我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著轩褐,像睡著了一般椎咧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上把介,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天勤讽,我揣著相機(jī)與錄音,去河邊找鬼拗踢。 笑死脚牍,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的巢墅。 我是一名探鬼主播诸狭,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼券膀,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了驯遇?” 一聲冷哼從身側(cè)響起芹彬,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎叉庐,沒想到半個月后舒帮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡陡叠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年玩郊,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片枉阵。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡瓦宜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出岭妖,到底是詐尸還是另有隱情临庇,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布昵慌,位于F島的核電站假夺,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏斋攀。R本人自食惡果不足惜已卷,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望淳蔼。 院中可真熱鬧侧蘸,春花似錦、人聲如沸鹉梨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽存皂。三九已至晌坤,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間旦袋,已是汗流浹背骤菠。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留疤孕,地道東北人商乎。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像祭阀,于是被迫代替她去往敵國和親鹉戚。 傳聞我的和親對象是個殘疾皇子爬泥,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,611評論 2 353

推薦閱讀更多精彩內(nèi)容