下面舉例說明什麼是一對一的資料對映。比如乙個班級中,每個學生的學號跟他的姓名就存在著一一對映的關係,這個模型用map可能輕易描述,很明顯學號用int描述,姓名用字串描述(本篇文章中不用char *來描述字串,而是採用stl中string來描述),下面給出map描述**:mapmapstudent;
1. map的建構函式
map共提供了6個建構函式,這塊涉及到記憶體分配器這些東西,略過不表,在下面我們將接觸到一些map的構造方法,
這裡要說下的就是,我們通常用如下方法構造乙個map:
mapmapstudent;
2. 資料的插入
在構造map容器後,我們就可以往裡面插入資料了。這裡講三種插入資料的方法:
第一種:用insert函式插入pair資料,下面舉例說明(以下**雖然是隨手寫的,應該可以在vc和gcc下編譯通過,
大家可以執行下看什麼效果,在vc下**入這條語句,遮蔽4786警告 #pragma warning (disable:4786) )
#include
#include
#include
using namespace std;
int main()
6.資料的清空與判空
清空map中的資料可以用clear()函式,判定map中是否有資料可以用empty()函式,它返回true則說明是空map
7. 資料的刪除
這裡要用到erase函式,它有三個過載了的函式,下面在例子中詳細說明它們的用法
#include
#include
#include
using namespace std;
int main()
mapmapstudent;
mapstudent.insert(pair(1, 「student_one」));
mapstudent.insert(pair(2, 「student_two」));
mapstudent.insert(pair(3, 「student_three」));
//如果你要演示輸出效果,請選擇以下的一種,你看到的效果會比較好
//如果要刪除1,用迭代器刪除
map::iterator iter;
iter = mapstudent.find(1);
mapstudent.erase(iter);
//如果要刪除1,用關鍵字刪除
int n = mapstudent.erase(1);//如果刪除了會返回1,否則返回0
//用迭代器,成片的刪除
//一下**把整個map清空
mapstudent.earse(mapstudent.begin(), mapstudent.end());
//成片刪除要注意的是,也是stl的特性,刪除區間是乙個前閉後開的集合
//自個加上遍歷**,列印輸出吧
}
STL之map的高階用法
stl之map的高階用法 stl中的容器map,對映和多重對映基於某一型別key的鍵集的存在,提供對t型別的資料進行快速和高效的檢索。對 map而言,鍵只是指儲存在容器中的某一成員。map不支援副本鍵,multimap支援副本鍵。map和multimap物件包涵了鍵和各個鍵有關的值,鍵 和值的資料型...
STL 中 map 的用法
說明 如果你具備一定的 c template知識,即使你沒有接觸過stl,這個文章你也應該可能較輕易的看懂。本人水平有限,不當之處,望大家輔正。一 map概述 map是stl的乙個關聯容器,它提供一對一 其中第乙個可以稱為關鍵字,每個關鍵字只能在map中出現一次,第二個可能稱為該關鍵字的值 的資料處...
C 中STL之map用法詳解
深夜無聊 把map的用法複習一遍 嘻嘻 標準庫map型別是一種以鍵 值 key value 儲存的資料型別。以下分別從以下的幾個方面總結 map物件的的定義和初始化 map物件的基本操作,重要包括新增元素,遍歷等1.1 pair型別的定義和初始化 pair型別是在有檔案utility中定義的,pai...