工作小結 22.04.07

1. vector 的 front()back()
vector.front()vector.back() 在空容器上調用會導致未定義的行為。
所以捎谨,如果想要使用 front()back()肢预,需要滿足容器不為空。

if (!arr.empty()) 
{
    // arr.front();
    // arr.back();
}

2. unordered_map 賦值后不保證順序
unordered_map 是基于哈希表的無序結構略板,在將 unordered_map 對象賦值給一個新的 unordered_map 時酸茴,前后兩個 unordered_map 的元素順序是不一致的让簿。

std::unordered_map<int, std::string> um;
um.emplace(1001, "111");
um.emplace(1012, "222");
um.emplace(1023, "333");
um.emplace(1044, "444");
um.emplace(1005, "555");
um.emplace(1016, "666");

for (auto const & i : um) {
    std::cout << i.first << " " << i.second << std::endl;
}

std::cout << "----------------------" << std::endl;

auto new_um = um;
for (auto const& i : new_um) {
    std::cout << i.first << " " << i.second << std::endl;
}

// 結果
// 1044 444
// 1001 111
// 1012 222
// 1023 333
// 1005 555
// 1016 666
// ----------------------
// 1001 111
// 1044 444
// 1012 222
// 1023 333
// 1005 555
// 1016 666

3. 獲取對象類型
C++ 中使用typeid()來獲取對象的類型信息

#include <iostream>
#include <typeinfo>

int main() {
  int i;
  std::cout << "i type is: " << typeid(i).name() << '\n';
  return 0;
}

// 結果
// i is: int

4. decltype
decltype用于選擇并返回操作數的數據類型,解決復雜的類型聲明漠畜。

  • 作用于變量:得到變量的類型
  • 作用于表達式:左值的表達式得到類型的引用币他;右值的表達式得到類型。且都不計算表達式的值
  • 作用于函數名:得到函數類型憔狞,不轉換成指針

auto蝴悉、typeid、decltype區(qū)別:

  • auto:推到類型瘾敢,且必須初始化
  • typeid:獲取類型拍冠,可用于類型的比較
  • decltype:獲取類型,僅用于聲明

decltype的使用場景:用于聲明模板函數簇抵,此模板函數的返回值類型依賴于其參數類型

// C++ 11
template<typename T, typename U>
auto add(T t, U u) -> decltype(t + u)
{
    return t + u;
}


// C++ 14
template<typename T, typename U>
auto add(T t, U u)
{
    return t + u;
}
// 在其所調用的函數返回引用的情況下
// 函數調用的完美轉發(fā)必須用 decltype(auto)
template<class F, class... Args>
decltype(auto) PerfectForward(F fun, Args&&... args) 
{ 
    return fun(std::forward<Args>(args)...); 
}


// C++17  支持 auto 形參聲明
template<auto n>
auto f() -> std::pair<decltype(n), decltype(n)> // auto 不能從花括號初始化器列表推導
{
    return { n, n + 1 };
}

int main() 
{
    auto arr = f<9>();
    std::cout << "arr.first :" << arr.first << " arr.second :" << arr.second << std::endl;
    return 0;
}
// 結果
// arr.first :9 arr.second :10
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末庆杜,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子碟摆,更是在濱河造成了極大的恐慌晃财,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件典蜕,死亡現場離奇詭異断盛,居然都是意外死亡,警方通過查閱死者的電腦和手機愉舔,發(fā)現死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門钢猛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人屑宠,你說我怎么就攤上這事〕鹑茫” “怎么了典奉?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵躺翻,是天一觀的道長。 經常有香客問我卫玖,道長公你,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任假瞬,我火速辦了婚禮陕靠,結果婚禮上,老公的妹妹穿的比我還像新娘脱茉。我一直安慰自己剪芥,他們只是感情好,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布琴许。 她就那樣靜靜地躺著税肪,像睡著了一般。 火紅的嫁衣襯著肌膚如雪榜田。 梳的紋絲不亂的頭發(fā)上益兄,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天,我揣著相機與錄音箭券,去河邊找鬼净捅。 笑死,一個胖子當著我的面吹牛辩块,可吹牛的內容都是我干的蛔六。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼庆捺,長吁一口氣:“原來是場噩夢啊……” “哼古今!你這毒婦竟也來了?” 一聲冷哼從身側響起滔以,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤捉腥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后你画,有當地人在樹林里發(fā)現了一具尸體抵碟,經...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年坏匪,在試婚紗的時候發(fā)現自己被綠了拟逮。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡适滓,死狀恐怖敦迄,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤罚屋,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布苦囱,位于F島的核電站,受9級特大地震影響脾猛,放射性物質發(fā)生泄漏撕彤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一猛拴、第九天 我趴在偏房一處隱蔽的房頂上張望羹铅。 院中可真熱鬧,春花似錦愉昆、人聲如沸职员。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽廉邑。三九已至,卻和暖如春倒谷,著一層夾襖步出監(jiān)牢的瞬間蛛蒙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工渤愁, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留牵祟,地道東北人。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓抖格,卻偏偏與公主長得像诺苹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子雹拄,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內容

  • 抱佛腳一時爽,一直抱佛腳一直爽滓玖!這篇文章總結常見的c++面試問題~因為是抱佛腳坪哄,所以結構上沒有什么邏輯...參考鏈...
    山幺幺閱讀 712評論 0 0
  • c++學習文檔匯總 [TOC] c++ primer部分 c++學習筆記 引用(左值引用) int &ref...
    flyrain閱讀 364評論 0 0
  • 自動類型推導 現代的編程語言,不管是動態(tài)語言(JavaScript势篡、Python 等)翩肌,還是靜態(tài)語言(Go、Rus...
    linjinhe閱讀 810評論 0 0
  • 官方答案2 思路:和常規(guī)方法一樣禁悠,還是通過查找target-nums[i]尋找下表念祭,但是用建立哈希表替代遍歷。 u...
    AnthonyM08閱讀 137評論 0 0
  • 一碍侦、C語言基礎 1粱坤、struct 的內存對齊和填充問題其實只要記住一個概念和三個原則就可以了: 一個概念:自然對齊...
    XDgbh閱讀 2,202評論 1 38