Geekband C++ 第六周

概述

  • Container
  • Stack矩动,Queue,Map和Set
  • STL中的仿函數(shù)诈嘿,適配器
  • 泛型算法之非變易算法

容器

Stack

  • 一種先進后出的數(shù)據(jù)結(jié)構(gòu)
  • 支持push,pop和top操作狰闪,只能訪問頂層元素,不允許遍歷
  • 以deque作為默認的底層結(jié)構(gòu)
  • (因為不支持遍歷)沒有iterator

Queue

  • 先進先出的數(shù)據(jù)結(jié)構(gòu)
  • 支持push濒生,pop,front幔欧,back操作罪治,不允許遍歷
  • 以deque作為默認底層結(jié)構(gòu)
  • (因為不支持遍歷)沒有iterator

Map

  • 一種關(guān)聯(lián)容器,存儲對象是key/value pair
  • 不允許有重復(fù)的key
  • map存儲的對象必須能夠排序礁蔗,默認采用less(仿函數(shù))定義排序行為觉义,可以自定義排序函數(shù)
  • 支持
    • 插入元素:insert
    • 刪除元素:erase
    • 取元素:[]

Set

  • 一種關(guān)聯(lián)容器,存儲對象本身是key又是value
  • 不允許有重復(fù)的key
  • 存儲的對象必須可以排序
  • 默認用less排序浴井,可以定義排序行為
  • 支持
    • 插入:insert
    • 刪除:erase
    • 并:set_union
    • 交:set_intersection
    • 差:set_difference
  • 通過iterator改變set的成員
    • const_cast<Person&>(*it).SetName(L"Bill Gates")
    • 其中Person是一set

STL的整體結(jié)構(gòu)

  • 容器通過內(nèi)存分配器分配空間
  • 容器和算法通過迭代器聯(lián)系
  • 仿函數(shù)協(xié)助算法完成不同的策略
  • 適配器套接仿函數(shù)

仿函數(shù)(Functor)

  • 類重載()晒骇,作用相當于一個函數(shù)指針
  • 可以用于模板實參,用于定義對象的行為
  • binder1st/binder2nd
    • 解決需要兩個參數(shù)的Functor用于泛型算法的問題磺浙,binder1st將一“常數(shù)”綁定到左操作數(shù)洪囤,作用相當于只接收一個參數(shù)的Functor
    • binder2nd將“常數(shù)”綁定在第二個操作數(shù)上
  • mem_fun
    • 支持在算法中使用類的成員函數(shù),否則只能使用全局函數(shù)


      mem_fun
  • mem_fun_ref
    • 某一容器中存放的是對象
    • 遍歷容器的算法時撕氧,支持使用類的成員函數(shù)


      mem_fun_ref

注意

  • 單線程下涉及對字符串的操作使用
  • string和wstring
  • 多線程下對字符串的操作使用
  • vector<char>和vector<wchar_t>
  • new出的對象放入容器時瘤缩,在銷毀容器前,delete那些對象
  • 盡量用算法代替手寫循環(huán)
  • 通過swap為容器“縮水”
  • 在有對象繼承的情況下伦泥,建立指針的容器而不是對象的容器

非變易算法

  • 一系列模板函數(shù)剥啤,在不改變操作對象的前提下對元素進行處理
  • for_each
  • find
  • find_if
  • adjacent_find
  • find_first_of
  • count
  • count_if
  • mismatch
  • equal
  • search
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市不脯,隨后出現(xiàn)的幾起案子府怯,更是在濱河造成了極大的恐慌,老刑警劉巖防楷,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牺丙,死亡現(xiàn)場離奇詭異,居然都是意外死亡复局,警方通過查閱死者的電腦和手機赘被,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肖揣,“玉大人民假,你說我怎么就攤上這事×牛” “怎么了羊异?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵事秀,是天一觀的道長。 經(jīng)常有香客問我野舶,道長易迹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任平道,我火速辦了婚禮睹欲,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘一屋。我一直安慰自己窘疮,他們只是感情好,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布冀墨。 她就那樣靜靜地躺著闸衫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪诽嘉。 梳的紋絲不亂的頭發(fā)上蔚出,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機與錄音虫腋,去河邊找鬼骄酗。 笑死,一個胖子當著我的面吹牛悦冀,可吹牛的內(nèi)容都是我干的酥筝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼雏门,長吁一口氣:“原來是場噩夢啊……” “哼嘿歌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起茁影,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤宙帝,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后募闲,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體步脓,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年浩螺,在試婚紗的時候發(fā)現(xiàn)自己被綠了靴患。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡要出,死狀恐怖鸳君,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情患蹂,我是刑警寧澤或颊,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布砸紊,位于F島的核電站,受9級特大地震影響囱挑,放射性物質(zhì)發(fā)生泄漏醉顽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一平挑、第九天 我趴在偏房一處隱蔽的房頂上張望游添。 院中可真熱鬧,春花似錦通熄、人聲如沸唆涝。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至檐嚣,卻和暖如春助泽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背嚎京。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工嗡贺, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鞍帝。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓诫睬,卻偏偏與公主長得像,于是被迫代替她去往敵國和親帕涌。 傳聞我的和親對象是個殘疾皇子摄凡,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

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