新聞中心
這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
c++中map索引不存在如何解決-創(chuàng)新互聯(lián)
今天就跟大家聊聊有關(guān)c++ 中map索引不存在如何解決,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
測(cè)試代碼
#includeusing namespace std; int main() { map mp_int; map mp_string; map mp_char; mp_int[1]=10; string a="abc",b="xzy",c="def"; mp_string[a]=b; mp_char['a']='b'; cout<<"正常索引"< OUT PUT
正常索引
1 10
abc xzy
a b
訪問不存在的鍵
0
變化
1 10
2 0
abc xzy
def
a b
c可以發(fā)現(xiàn)不存在的key在被索引后被添加到了map中并被賦予了一個(gè)默認(rèn)值(一般的,整數(shù)為0,字符,字符串為空)
需要注意的是,只要發(fā)生了索引,就會(huì)導(dǎo)致如上錯(cuò)誤,即使他們?cè)趇f語句里
#includeusing namespace std; int main() { map mp_int; map mp_string; map mp_char; mp_int[1]=10; string a="abc",b="xzy",c="def"; mp_string[a]=b; mp_char['a']='b'; cout<<"正常索引"< 上面的代碼會(huì)產(chǎn)生同樣的結(jié)果
當(dāng)你想要再次使用(循環(huán))這些鍵的時(shí)候就會(huì)出錯(cuò),你會(huì)使用到實(shí)際并不存在的key
避免方法是在索引前使用find或者count來判斷鍵是否存在
看完上述內(nèi)容,你們對(duì)c++ 中map索引不存在如何解決有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
分享名稱:c++中map索引不存在如何解決-創(chuàng)新互聯(lián)
文章起源:http://www.dlmjj.cn/article/deedhe.html