1、map介绍

map是STL的一个关联容器,map内部自建一颗红黑树。它的特点是增加和删除节点对迭代器的影响很小,除了那个操作节点,对其他的节点都没有什么影响。对于迭代器来说,可以修改实值,而不能修改key。

2、map的定义

#include <map> 
std:map<int,string> mapS;
typedef map<int,CString> MapNToStr;//为了使用方便
MapNToStr enumMap;

3、map的插入方法

(1)enumMap.insert(pair<int, Cstring>(1, “One”));

(2)enumMap.insert(map<int, Cstring>::value_type (1, “One”)); 

(3)enumMap[1] = "One";  

4、编程实现find()、begin()、end()函数的使用,三者均返回的是迭代器类型。

//map的定义
    std::map<int, QString> m_map;
    m_map[1] = "a";
    m_map.insert(std::pair<int, QString>(2, "b"));
    m_map.insert(std::pair<int, QString>(3, "c"));
    m_map.insert(std::pair<int, QString>(4, "d"));
    m_map.insert(std::pair<int, QString>(5, "e"));
    m_map[6] = "f";
    m_map[7] = "g";
    m_map.insert(std::map<int, QString>::value_type(8, "h"));
    m_map[9] = QString("student_1");

    //map的find()函数
    std::map<int, QString>::iterator iter;
    iter = m_map.find(1);//find()返回的是一个迭代器

    if (iter != m_map.end())
    {
        qDebug() << "Find the value is " << iter->second << endl;
    }
    else
    {
        qDebug() << "Do not Find" << endl;
    }

//map的循环    

std::map<int, QString>::iterator iter1;
    for (iter1 = m_map.begin(); iter1 != m_map.end(); iter1++)//begin和end均返回迭代器类型
    {
        qDebug() << iter1->first << ": " << iter1->second << endl;
    }

5、擦除元素

iterator erase(iterator it);        //通过一个条目对象删除(操作迭代器)
iterator erase(iterator first,iterator last);    //删除一个范围(操作迭代器)
size_type erase(const Key&key);        //通过关键字删除

    //擦除map数据
    std::map<int, QString>::iterator iter2;
    iter2 = m_map.find(3);
    m_map.erase(iter2);

    iter2 = m_map.find(3);
    if (iter2 == m_map.end())
    {
        qDebug() << "Do not find";
    }

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐