3D游戲引擎底層數(shù)據(jù)結(jié)構(gòu)封裝之List

相信很多開(kāi)發(fā)者在游戲開(kāi)發(fā)中都會(huì)用到List表笼痹,用于存儲(chǔ)數(shù)據(jù)或者對(duì)象坞靶。估計(jì)也有很多人對(duì)它的實(shí)現(xiàn)并不清楚,只是會(huì)用而已琅催。學(xué)習(xí)知識(shí)不能僅限于表面居凶,如果抱著只是會(huì)用,時(shí)間長(zhǎng)了對(duì)自己的技能提升沒(méi)有任何幫助不進(jìn)則退藤抡,相信大家都學(xué)過(guò)侯捷先生的書侠碧,它編寫的C++都是底層的實(shí)現(xiàn)。作為開(kāi)發(fā)者來(lái)說(shuō)缠黍,如果對(duì)知識(shí)的掌握只限于表面弄兜,長(zhǎng)久下去把自己就廢了。因?yàn)楝F(xiàn)在引擎都封裝的非常完善,其實(shí)這樣做的后果就是引擎的關(guān)鍵技術(shù)只是掌握在少數(shù)人手中替饿,大部分開(kāi)發(fā)者都是邏輯程序員语泽,一直要依附于人家才能生活,這樣很可悲的视卢,作為開(kāi)發(fā)者的我們更應(yīng)該自己主動(dòng)的去學(xué)習(xí)踱卵。這樣即使引擎有問(wèn)題,自己也可以輕松解決据过。本章主要是給讀者介紹關(guān)于List的封裝惋砂,List是鏈表,表是有結(jié)點(diǎn)組成的绳锅,鏈表的遍歷可以使用迭代器實(shí)現(xiàn)西饵,這些就組成了鏈表的封裝。

首先看看迭代器的定義:

[cpp]
/// the list iterator  
   class Iterator  
   {  
   public:  
       /// default constructor  
       Iterator();  
       /// constructor  
       Iterator(Node* node);  
       /// copy constructor  
       Iterator(const Iterator& rhs);  
       /// assignment operator  
       const Iterator& operator=(const Iterator& rhs);  
       /// equality operator  
       bool operator==(const Iterator& rhs) const;  
       /// inequality operator  
       bool operator!=(const Iterator& rhs) const;  
       /// pre-increment operator  
       const Iterator& operator++();  
       /// post-increment operator  
       Iterator operator++(int);  
       /// pre-decrement operator  
       const Iterator& operator--();  
       /// post-increment operator  
       Iterator operator--(int);  
       /// bool operator  
       operator bool() const;  
       /// safe -> operator  
       TYPE* operator->() const;  
       /// safe dereference operator  
       TYPE& operator*() const;  
   private:  
       friend class List<TYPE>;  
  
       /// access to node  
       Node* GetNode() const;  
  
       Node* node;  
   };  
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鳞芙,一起剝皮案震驚了整個(gè)濱河市眷柔,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌原朝,老刑警劉巖驯嘱,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異竿拆,居然都是意外死亡宙拉,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門丙笋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)谢澈,“玉大人,你說(shuō)我怎么就攤上這事御板∽斗蓿” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵怠肋,是天一觀的道長(zhǎng)敬鬓。 經(jīng)常有香客問(wèn)我,道長(zhǎng)笙各,這世上最難降的妖魔是什么钉答? 我笑而不...
    開(kāi)封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮杈抢,結(jié)果婚禮上数尿,老公的妹妹穿的比我還像新娘。我一直安慰自己惶楼,他們只是感情好右蹦,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布诊杆。 她就那樣靜靜地躺著,像睡著了一般何陆。 火紅的嫁衣襯著肌膚如雪晨汹。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天贷盲,我揣著相機(jī)與錄音淘这,去河邊找鬼。 笑死巩剖,一個(gè)胖子當(dāng)著我的面吹牛慨灭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播球及,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼呻疹!你這毒婦竟也來(lái)了吃引?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤刽锤,失蹤者是張志新(化名)和其女友劉穎镊尺,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體并思,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡庐氮,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了宋彼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弄砍。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖输涕,靈堂內(nèi)的尸體忽然破棺而出音婶,到底是詐尸還是另有隱情,我是刑警寧澤莱坎,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布衣式,位于F島的核電站,受9級(jí)特大地震影響檐什,放射性物質(zhì)發(fā)生泄漏碴卧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一乃正、第九天 我趴在偏房一處隱蔽的房頂上張望住册。 院中可真熱鬧,春花似錦烫葬、人聲如沸界弧。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)垢箕。三九已至划栓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間条获,已是汗流浹背忠荞。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留帅掘,地道東北人委煤。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像修档,于是被迫代替她去往敵國(guó)和親碧绞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,129評(píng)論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)吱窝、插件讥邻、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,103評(píng)論 4 62
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法院峡,內(nèi)部類的語(yǔ)法兴使,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法照激,線程的語(yǔ)...
    子非魚_t_閱讀 31,631評(píng)論 18 399
  • 手機(jī)上的APP實(shí)在是太多了赏淌,比較熱門的手機(jī)APP大家都知道,但其實(shí)還有許多小眾的APP也是非常好用的啄清,下面小編就給...
    時(shí)光與我同眠閱讀 494評(píng)論 0 3
  • 小時(shí)候我以為辣卒,長(zhǎng)大了就可以跟姐姐一樣高掷贾。直至我到了初三時(shí),身高還停滯在六年級(jí)荣茫,我才黯然神傷想帅,有些事情埋怨不了時(shí)間。...
    思峯如飴閱讀 67評(píng)論 0 0