map<Key, Data, Compare, Alloc>
map是一種關聯容器,存儲相結合形成的一個關鍵值和映射值的元素。Map 是一種Pair Associative Container,意味着它的值類型為 pair<const Key, Data>. 而且也是 Unique Associative Container, 也就是任何兩個元素沒有相同的key值。
map具有重要的屬性,就是在map對象中插入一個新元素不指向現有元素的迭代器失效。從map上刪除一個元素,也沒有任何迭代器失效,除非,當然,實際上指向正在被刪除的元素的迭代器。
1、例子
- struct ltstr
- {
- bool operator()(const char* s1, const char* s2) const
- {
- return strcmp(s1, s2) < 0;
- }
- };
- int main()
- {
- map<const char*, int, ltstr> months;
- months["january"] = 31;
- months["february"] = 28;
- months["march"] = 31;
- months["april"] = 30;
- months["may"] = 31;
- months["june"] = 30;
- months["july"] = 31;
- months["august"] = 31;
- months["september"] = 30;
- months["october"] = 31;
- months["november"] = 30;
- months["december"] = 31;
- cout << "june -> " << months["june"] << endl;
- map<const char*, int, ltstr>::iterator cur = months.find("june");
- map<const char*, int, ltstr>::iterator prev = cur;
- map<const char*, int, ltstr>::iterator next = cur;
- ++next;
- --prev;
- cout << "Previous (in alphabetical order) is " << (*prev).first << endl;
- cout << "Next (in alphabetical order) is " << (*next).first << endl;
- }
2、定義形式
- template < class Key, class T, class Compare = less<Key>,
- class Allocator = allocator<pair<const Key,T> > > class map;
3、模板參數具有以下涵義:
key:關鍵值的類型。在map對象中的每個元素是通過該關鍵值唯一確定元素的。
T:映射值的類型。在map中的每個元素是用來儲存一些數據作為其映射值。
compare:Comparison類:A類鍵的類型,它有兩個參數,並返回一個bool。表達comp(A,B),comp是這比較類A和B是關鍵值的對象,應返回true,如果是在早先的立場比B放置在一個嚴格弱排序操作。這可以是一個類實現一個函數調用運算符或一個函數的指針(見一個例子構造)。默認的對於<KEY>,返回申請小於操作符相同的默認值(A <B)。
Map對象使用這個表達式來確定在容器中元素的位置。以下這個規則在任何時候都排列在map容器中的所有元素。
Allocator:用於定義存儲分配模型分配器對象的類型。默認情況下,分配器類模板,它定義了最簡單的內存分配模式,是值獨立的
- map<Key,T>::iterator it;
- (*it).first; // 指向key值(of type Key)
- (*it).second; // 映射的值(of type T)
- (*it); // the "element value" (of type pair<const Key,T>) //看到此處懵逼啊有木有!!(*it)到底該如何表述,查CPLUSPLUS pair 如下:
- -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
- class template
-
<utility>
-
std::pair
-
template <class T1, class T2> struct pair;Pair of valuesThis class couples together a pair of values, which may be of different types (T1 and T2). The individual values can be accessed through its public members first and second. 是一對值
Pairs are a particular case of tuple. pairs是一特定的元祖,然后我搜了tuple, -
class template<tuple>
std::tuple
template <class... Types> class tuple;
TupleA tuple is an object capable to hold a collection of elements. Each element can be of a different type. tuple是一個能夠容納元素集合的obiect。每個元素可以是不同的類型。 - it本身是迭代器, (*it)默認指迭代器內部第一個鍵值對(tuple元組) //尼瑪,看半天才知道此處專業叫法是迭代器里邊的‘解引用操作符’,指向其內部元素!!
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
也可以如下表達:
- it->first; // same as (*it).first (the key value)
- it->second; // same as (*it).second (the mapped value)
4、成員變量和成員函數
Member | Where defined | Description |
---|---|---|
key_type | Associative Container | map中的key類型 |
data_type | Pair Associative Container | key關聯的值類型 |
value_type | Pair Associative Container | 對象類型, pair<const key_type, data_type>,存儲在map中 |
key_compare | Sorted Associative Container | Function object 通過順序比較 |
value_compare | Sorted Associative Container | Function object that compares two values for ordering. |
pointer | Container | Pointer to T. |
reference | Container | Reference to T |
const_reference | Container | Const reference to T |
size_type | Container | An unsigned integral type. |
difference_type | Container | A signed integral type. |
iterator | Container | Iterator used to iterate through a map. [1] |
const_iterator | Container | Const iterator used to iterate through a map. |
reverse_iterator | Reversible Container | Iterator used to iterate backwards through a map.[1] |
const_reverse_iterator | Reversible Container | Const iterator used to iterate backwards through amap. |
iterator begin() | Container | Returns an iterator pointing to the beginning of the map. |
iterator end() | Container | Returns an iterator pointing to the end of the map. |
const_iterator begin() const | Container | Returns a const_iterator pointing to the beginning of themap. |
const_iterator end() const | Container | Returns a const_iterator pointing to the end of the map. |
reverse_iterator rbegin() | Reversible Container | Returns a reverse_iterator pointing to the beginning of the reversed map. |
reverse_iterator rend() | Reversible Container | Returns a reverse_iterator pointing to the end of the reversed map. |
const_reverse_iterator rbegin() const | Reversible Container | Returns a const_reverse_iterator pointing to the beginning of the reversed map. |
const_reverse_iterator rend() const | Reversible Container | Returns a const_reverse_iterator pointing to the end of the reversed map. |
size_type size() const | Container | Returns the size of the map. |
size_type max_size() const | Container | Returns the largest possible size of the map. |
bool empty() const | Container | true if the map's size is 0. |
key_compare key_comp() const | Sorted Associative Container | Returns the key_compare object used by the map. |
value_compare value_comp() const | Sorted Associative Container | Returns the value_compare object used by the map. |
map() | Container | Creates an empty map. |
map(const key_compare& comp) | Sorted Associative Container | Creates an empty map, using comp as thekey_compare object. |
template <class InputIterator>
map(InputIterator f, InputIterator l)
|
Unique Sorted Associative Container | Creates a map with a copy of a range. |
template <class InputIterator>
map(InputIterator f, InputIterator l,
const key_compare& comp)
|
Unique Sorted Associative Container | Creates a map with a copy of a range, using compas thekey_compare object. |
map(const map&) | Container | The copy constructor. |
map& operator=(const map&) | Container | The assignment operator |
void swap(map&) | Container | Swaps the contents of two maps. |
pair<iterator, bool>
insert(const value_type& x)
|
Unique Associative Container | Inserts x into the map. |
iterator insert(iterator pos,
const value_type& x)
|
Unique Sorted Associative Container | Inserts x into the map, using pos as a hint to where it will be inserted. |
template <class InputIterator>
void insert(InputIterator, InputIterator)
[2]
|
Unique Sorted Associative Container | Inserts a range into the map. |
void erase(iterator pos) | Associative Container | Erases the element pointed to by pos. |
size_type erase(const key_type& k) | Associative Container | Erases the element whose key is k. |
void erase(iterator first, iterator last) | Associative Container | Erases all elements in a range. |
void clear() | Associative Container | Erases all of the elements. |
iterator find(const key_type& k) | Associative Container | Finds an element whose key is k. |
const_iterator find(const key_type& k) const | Associative Container | Finds an element whose key is k. |
size_type count(const key_type& k) | Unique Associative Container | Counts the number of elements whose key is k. |
iterator lower_bound(const key_type& k) | Sorted Associative Container | Finds the first element whose key is not less thank. |
const_iterator lower_bound(const key_type& k) const | Sorted Associative Container | Finds the first element whose key is not less thank. |
iterator upper_bound(const key_type& k) | Sorted Associative Container | Finds the first element whose key greater than k. |
const_iterator upper_bound(const key_type& k) const | Sorted Associative Container | Finds the first element whose key greater than k. |
pair<iterator, iterator>
equal_range(const key_type& k)
|
Sorted Associative Container | Finds a range containing all elements whose key isk. |
pair<const_iterator, const_iterator>
equal_range(const key_type& k) const
|
Sorted Associative Container | Finds a range containing all elements whose key isk. |
data_type&
operator[](const key_type& k) [3]
|
map | See below. |
bool operator==(const map&,
const map&)
|
Forward Container | Tests two maps for equality. This is a global function, not a member function. |
bool operator<(const map&,
const map&)
|
Forward Container | Lexicographical comparison. This is a global function, not a member function. |
- 下面展示了常用的一些方法。<p>// stu_map.cpp : 定義控制台應用程序的入口點。
- //
- #include "stdafx.h"
- #include <iostream>
- #include <map>
- using namespace std;
- bool fncomp(char lhs,char rhs)
- {
- return lhs<rhs;
- }
- struct classcomp
- {
- bool operator()(const char& lhs,const char& rhs)
- {
- return lhs<rhs;
- }
- };
- int _tmain(int argc, _TCHAR* argv[])
- {
- map<char,int> mymap;
- mymap['a']=10;
- mymap['b']=60;
- mymap['c']=30;
- mymap['d']=90;
- mymap['e']=50;
- map<char,int> second(mymap);
- map<char,int> third(mymap.begin(),mymap.end());
- map<char,int,classcomp> fourth;
- bool(*fn_pt)(char,char)=fncomp;
- map<char,int,bool(*)(char,char)> fifth(fn_pt);
- map<char,int>::key_compare key_comp;
- map<char,int>::iterator it;
- it=mymap.begin();
- for (it;it!=mymap.end();it++)
- {
- cout<<it->first<<":"<<it->second<<endl;
- }
- cout<<"================================="<<endl;
- second.clear();
- second['a']=1002;
- second['b']=10023;
- while (!second.empty())
- {
- cout << second.begin()->first << " => ";
- cout << second.begin()->second << endl;
- second.erase(second.begin());
- }
- cout<<"================================="<<endl;
- mymap.insert(pair<char,int>('f',100) );
- mymap.insert(pair<char,int>('g',200) );
- cout<<"f => " <<mymap.find('f')->second<<endl;
- cout<<"g => " <<mymap.find('g')->second<<endl;
- cout<<"================================="<<endl;
- key_comp=mymap.key_comp();
- cout << "mymap contains:\n";
- char highest=mymap.rbegin()->first; // key value of last element
- it=mymap.begin();
- do {
- cout << (*it).first << " => " << (*it).second << endl;
- } while ( key_comp((*it++).first, highest) );
- cout << endl;
- return 0;
- }
- </p>
運行結果: