亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++中 map的基本操作

2020-01-26 14:09:10
字體:
來源:轉載
供稿:網友

1、map簡介

map是一類關聯式容器。它的特點是增加和刪除節點對迭代器的影響很小,除了那個操作節點,對其他的節點都沒有什么影響。對于迭代器來說,可以修改實值,而不能修改key。

2、map的功能

自動建立Key - value的對應。key 和 value可以是任意你需要的類型。

根據key值快速查找記錄,查找的復雜度基本是Log(N),如果有1000個記錄,最多查找10次,1,000,000個記錄,最多查找20次。

快速插入Key - Value 記錄。

快速刪除記錄

根據Key 修改value記錄。

遍歷所有記錄。

3、使用map

使用map得包含map類所在的頭文件

#include <map> //注意,STL頭文件沒有擴展名.h

map對象是模板類,需要關鍵字和存儲對象兩個模板參數:

std:map<int, string> personnel;

這樣就定義了一個用int作為索引,并擁有相關聯的指向string的指針.

為了使用方便,可以對模板類進行一下類型定義,

typedef map<int, CString> UDT_MAP_INT_CSTRING;UDT_MAP_INT_CSTRING enumMap;

4、在map中插入元素

改變map中的條目非常簡單,因為map類已經對[]操作符進行了重載

enumMap[1] = "One";enumMap[2] = "Two";

.....

這樣非常直觀,但存在一個性能的問題。插入2時,先在enumMap中查找主鍵為2的項,沒發現,然后將一個新的對象插入enumMap,鍵是2,值是一個空字符串,插入完成后,將字符串賦為"Two"; 該方法會將每個值都賦為缺省值,然后再賦為顯示的值,如果元素是類對象,則開銷比較大。我們可以用以下方法來避免開銷:

enumMap.insert(map<int, CString> :: value_type(2, "Two"))

5、查找并獲取map中的元素

下標操作符給出了獲得一個值的最簡單方法:

CString tmp = enumMap[2];

但是,只有當map中有這個鍵的實例時才對,否則會自動插入一個實例,值為初始化值。

我們可以使用Find()和Count()方法來發現一個鍵是否存在。

查找map中是否包含某個關鍵字條目用find()方法,傳入的參數是要查找的key,在這里需要提到的是begin()和end()兩個成員,分別代表map對象中第一個條目和最后一個條目,這兩個數據的類型是iterator.

int nFindKey = 2; //要查找的Key//定義一個條目變量(實際是指針)UDT_MAP_INT_CSTRING::iterator it= enumMap.find(nFindKey);if(it == enumMap.end()) {//沒找到}else {//找到}

通過map對象的方法獲取的iterator數據類型是一個std::pair對象,包括兩個數據 iterator->first 和 iterator->second 分別代表關鍵字和存儲的數據

6、從map中刪除元素

移除某個map中某個條目用erase()

該成員方法的定義如下

iterator erase(iterator it); //通過一個條目對象刪除 iterator erase(iterator first, iterator last); //刪除一個范圍 size_type erase(const Key& key); //通過關鍵字刪除 clear()就相當于 enumMap.erase(enumMap.begin(), enumMap.end());

7、map的基本操作函數:

      C++ Maps是一種關聯式容器,包含“關鍵字/值”對
      begin()          返回指向map頭部的迭代器
      clear()         刪除所有元素
      count()          返回指定元素出現的次數
      empty()          如果map為空則返回true
      end()            返回指向map末尾的迭代器
      equal_range()    返回特殊條目的迭代器對
      erase()          刪除一個元素
      find()           查找一個元素
      get_allocator()  返回map的配置器
      insert()         插入元素
      key_comp()       返回比較元素key的函數
      lower_bound()    返回鍵值>=給定元素的第一個位置
      max_size()       返回可以容納的最大元素個數
      rbegin()         返回一個指向map尾部的逆向迭代器
      rend()           返回一個指向map頭部的逆向迭代器
      size()           返回map中元素的個數
      swap()            交換兩個map
      upper_bound()     返回鍵值>給定元素的第一個位置
      value_comp()      返回比較元素value的函數

例子:

//遍歷:map<string,CAgent>::iterator iter; for(iter = m_AgentClients.begin(); iter != m_AgentClients.end(); ++iter) {  if(iter->first=="8001" {    this->SendMsg(iter->second.pSocket,strMsg);//iter->first  } }//查找:map<string,CAgent>::iterator iter=m_AgentClients.find(strAgentName); if(iter!=m_AgentClients.end())//有重名的 { } else //沒有{ }//元素的個數if (m_AgentClients.size()==0)//刪除map<string,CAgent>::iterator iter=m_AgentClients.find(pSocket->GetName()); if(iter!=m_AgentClients.end()) {   m_AgentClients.erase(iter);//列表移除 }

以上所述是小編給大家介紹的C++中 map的基本操作 ,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人国产精品一区| 国产精品91在线观看| 91久久综合亚洲鲁鲁五月天| 欧美成人在线免费| 77777少妇光屁股久久一区| 久久久久免费视频| 日韩中文字幕免费| 最近2019中文字幕mv免费看| 精品久久中文字幕久久av| 久久韩国免费视频| 国产一区二区日韩| 成人在线观看视频网站| 久久中国妇女中文字幕| 欧美午夜精品久久久久久浪潮| 亚洲欧美日韩一区二区三区在线| 亚洲欧美日韩一区二区三区在线| 91青草视频久久| 欧美有码在线观看视频| 日韩视频在线免费| 国产精品1234| 欧美丝袜美女中出在线| 亚洲奶大毛多的老太婆| 日韩有码片在线观看| 欧洲亚洲免费在线| 69久久夜色精品国产69| 欧美成人小视频| 日本在线观看天堂男亚洲| 欧美孕妇毛茸茸xxxx| 欧美激情国内偷拍| 精品偷拍一区二区三区在线看| 在线成人中文字幕| 日韩美女毛茸茸| 亚洲第一色中文字幕| 国产国语刺激对白av不卡| 亚洲精品小视频在线观看| 久久久免费观看视频| 国产成人一区二区三区电影| 国产成人在线播放| 久久久国产影院| 国产日韩中文在线| 国产精品青草久久久久福利99| 97精品欧美一区二区三区| 精品人伦一区二区三区蜜桃网站| 色老头一区二区三区| 一区二区福利视频| 日韩av网址在线| 精品国产乱码久久久久酒店| 欧美国产日韩精品| 久久成年人视频| 中文字幕精品—区二区| 亚洲午夜精品久久久久久性色| 欧亚精品中文字幕| 久久久久亚洲精品| 国产精品久久久久久久久久| 欧美巨猛xxxx猛交黑人97人| 日韩av大片免费看| 日韩免费电影在线观看| 国产欧美一区二区三区四区| 成人免费视频a| 中文字幕少妇一区二区三区| 欧美亚洲成人xxx| 国产成人精品久久二区二区91| 欧美日韩中文字幕| 久久成人精品电影| 亚洲va欧美va在线观看| 久久91亚洲精品中文字幕奶水| 97视频免费看| 久久久最新网址| www.日韩系列| 疯狂欧美牲乱大交777| 91精品国产777在线观看| 国产一区二区色| 国产亚洲欧美aaaa| 91手机视频在线观看| 亚洲成年人影院在线| 国产一区二区在线免费| 伊是香蕉大人久久| 国语自产精品视频在线看| 国产美女精品视频| 亚洲视频国产视频| 国产精品一区二区久久久| 91精品久久久久久久久中文字幕| 精品久久久久久久久久久久久久| 精品国产老师黑色丝袜高跟鞋| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲视频网站在线观看| 欧美视频国产精品| 欧美三级xxx| 久久精品久久久久电影| 狠狠躁天天躁日日躁欧美| 欧美国产精品日韩| 亚洲精品美女久久久久| 国产精品99久久久久久久久久久久| 欧美成aaa人片在线观看蜜臀| 精品久久久久久亚洲国产300| 亚洲网址你懂得| 久久精品国产96久久久香蕉| 国产精品色午夜在线观看| 久久中文精品视频| 亚洲国产精品一区二区久| 欧美在线一级va免费观看| 亚洲天堂av图片| 91午夜理伦私人影院| 成人精品视频在线| 2019亚洲男人天堂| 国产精品久久久久久一区二区| 在线观看日韩专区| 中文字幕在线看视频国产欧美在线看完整| 91免费人成网站在线观看18| 国产精品免费看久久久香蕉| 欧美精品一区在线播放| 国产精品国模在线| 日韩av一区二区在线观看| 色偷偷噜噜噜亚洲男人| 久久久精品久久久久| 日韩精品久久久久久福利| 国产福利成人在线| 一本一本久久a久久精品综合小说| 伊人久久综合97精品| 91视频免费在线| 国产在线精品成人一区二区三区| 韩国国内大量揄拍精品视频| 国产精品xxx视频| 亚洲精品视频免费在线观看| 国产日韩欧美视频| 国产精品成熟老女人| 欧美日韩一区二区免费在线观看| 日韩精品中文字幕视频在线| 色一情一乱一区二区| 亚洲欧洲一区二区三区在线观看| 精品久久久在线观看| 性金发美女69hd大尺寸| 国产精品久久久久久久久男| 国产精品日韩av| 亚洲人成自拍网站| 91精品国产成人| 性欧美xxxx视频在线观看| 欧美一区深夜视频| 国外成人免费在线播放| 国产91ⅴ在线精品免费观看| 国色天香2019中文字幕在线观看| 欧美日韩午夜剧场| 91免费看片在线| 欧美日韩福利在线观看| 日本道色综合久久影院| 国产精品激情av电影在线观看| 国产成人精品久久| 国产午夜精品视频免费不卡69堂| 久久久国产精品一区| 欧美在线不卡区| 久久99久久99精品中文字幕| 国产精品尤物福利片在线观看| 欧美性生活大片免费观看网址| 亚洲美女av在线播放| 久久人人看视频| 欧美影院成年免费版| 亚洲加勒比久久88色综合| 欧美激情区在线播放| 自拍偷拍亚洲在线| 亚洲国产高清高潮精品美女| xvideos亚洲| 国产69精品久久久久久| 亚洲欧美日韩国产中文专区| 久久这里有精品视频|