1. 程式人生 > 實用技巧 >STL map常用用法整理

STL map常用用法整理

1,map簡介

map是STL的一個關聯容器,它提供一對一的hash。

  • 第一個可以稱為關鍵字(key),每個關鍵字只能在map中出現一次;
  • 第二個可能稱為該關鍵字的值(value);


map以模板(泛型)方式實現,可以儲存任意型別的資料,包括使用者自定義的資料型別。Map主要用於資料一對一對映(one-to-one)的情況,map內部的實現自建一顆紅黑樹,這顆樹具有對資料自動排序的功能。在map內部所有的資料都是有序的,後邊我們會見識到有序的好處。比如一個班級中,每個學生的學號跟他的姓名就存在著一對一對映的關係。

2,map的功能

自動建立key- value的對應。key 和 value可以是任意你需要的型別,包括自定義型別。

3,使用map

使用map得包含map類所在的標頭檔案

#include <map>//注意,STL標頭檔案沒有副檔名.h

map物件是模板類,需要關鍵字和儲存物件兩個模板引數:

std:map<int, string>personnel;

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

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

typedefmap<int,CString>UDT_MAP_INT_CSTRING;

UDT_MAP_INT_CSTRING enumMap;

4,map的建構函式

map共提供了6個建構函式,這塊涉及到記憶體分配器這些東西,略過不表,在下面我們將接觸到一些map的構造方法,這裡要說下的就是,我們通常用如下方法構造一個map:

map<int,string>mapStudent;

5,插入元素

  1. // 定義一個map物件
  2. map<int,string>mapStudent;
  3. // 第一種 用insert函式插入pair
  4. mapStudent.insert(pair<int, string>(000, "student_zero"));
  5. // 第二種 用insert函式插入value_type資料
  6. mapStudent.insert(map<int, string>::value_type(001, "student_one"));
  7. // 第三種 用"array"方式插入
  8. mapStudent[123
    ] = "student_first";
  9. mapStudent[456] = "student_second";

以上三種用法,雖然都可以實現資料的插入,但是它們是有區別的,當然了第一種和第二種在效果上是完成一樣的,用insert函式插入資料,在資料的插入上涉及到集合的唯一性這個概念,即當map中有這個關鍵字時,insert操作是不能在插入資料的,但是用陣列方式就不同了,它可以覆蓋以前該關鍵字對應的值,用程式說明如下:

  1. mapStudent.insert(map<int, string>::value_type (001, "student_one"));
  2. mapStudent.insert(map<int, string>::value_type (001, "student_two"));

上面這兩條語句執行後,map中001這個關鍵字對應的值是“student_one”,第二條語句並沒有生效,那麼這就涉及到我們怎麼知道insert語句是否插入成功的問題了,可以用pair來獲得是否插入成功,程式如下

  1. // 構造定義,返回一個pair物件
  2. pair<iterator,bool> insert (const value_type& val);
  3. pair<map<int, string>::iterator, bool> Insert_Pair;
  4. Insert_Pair = mapStudent.insert(map<int, string>::value_type (001, "student_one"));
  5. if(!Insert_Pair.second)
  6. cout << ""Error insert new element" << endl;

我們通過pair的第二個變數來知道是否插入成功,它的第一個變數返回的是一個map的迭代器,如果插入成功的話Insert_Pair.second應該是true的,否則為false。

6,查詢元素

當所查詢的關鍵key出現時,它返回資料所在物件的位置,如果沒有,返回iter與end函式的值相同。

  1. // find 返回迭代器指向當前查詢元素的位置否則返回map::end()位置
  2. iter = mapStudent.find("123");
  3. if(iter != mapStudent.end())
  4. cout<<"Find, the value is"<<iter->second<<endl;
  5. else
  6. cout<<"Do not Find"<<endl;

7,刪除與清空元素

  1. //迭代器刪除
  2. iter = mapStudent.find("123");
  3. mapStudent.erase(iter);
  4. //用關鍵字刪除
  5. int n = mapStudent.erase("123"); //如果刪除了會返回1,否則返回0
  6. //用迭代器範圍刪除 : 把整個map清空
  7. mapStudent.erase(mapStudent.begin(), mapStudent.end());
  8. //等同於mapStudent.clear()

8,map的大小

在往map裡面插入了資料,我們怎麼知道當前已經插入了多少資料呢,可以用size函式,用法如下:

int nSize = mapStudent.size();

9,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的函式