千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > 详解map.insert()

详解map.insert()

来源:千锋教育
发布人:xqq
时间: 2023-11-23 13:36:50 1700717810

一、map.insert用法

map.insert用于向一个map中插入一个元素,返回一个pair,第一个元素是插入元素的迭代器,第二个元素是一个bool值,表示插入成功或者失败。


#include 
#include 

int main()
{
    std::map my_map;

    my_map.insert(std::pair(1, 'a')); // 使用pair插入元素
    my_map.insert(std::make_pair(2, 'b')); // 使用make_pair插入元素
    my_map.insert(std::map::value_type(3, 'c')); // 使用value_type插入元素

    return 0;
}

二、map.insert初始化

如果我们想要初始化一个map,可以使用以下代码:


#include 
#include 

int main()
{
    std::map my_map = {{1, "hello"}, {2, "world"}}; // 使用花括号列表初始化

    return 0;
}

三、map.insert 异常

在插入元素时,可能会发生重复插入的情况,此时会返回一个bool值表示插入是否成功。


#include 
#include 

int main()
{
    std::map my_map = {{1, 'a'}, {2, 'b'}};

    bool success = my_map.insert(std::pair(1, 'c')).second; // 插入重复元素,返回false

    return 0;
}

四、map.insert返回值

map.insert函数的返回值为一个pair,第一个元素是插入元素的迭代器,第二个元素为bool值表示插入是否成功。


#include 
#include 

int main()
{
    std::map my_map = {{1, 'a'}, {2, 'b'}};

    std::pair::iterator, bool> ret = 
        my_map.insert(std::pair(3, 'c')); // 返回插入元素的迭代器和bool值

    if (ret.second == false) { // 插入不成功
        std::cout << "Element already exists in map" << std::endl;
        std::cout << "Value of key " << ret.first->first << " : " << ret.first->second << std::endl;
    }
    else { // 插入成功
        std::cout << "New element added to map" << std::endl;
        std::cout << "Value of key " << ret.first->first << " : " << ret.first->second << std::endl;
    }

    return 0;
}

五、map.insert()内存泄漏

在C++中,使用new关键字动态分配内存时,需要手动调用delete来释放内存,否则会造成内存泄漏。在使用map.insert()插入指针时,也需要注意内存泄漏的问题。


#include 
#include 

int main()
{
    std::map my_map;

    char* ptr = new char('a'); // 动态分配内存
    my_map.insert(std::make_pair(1, ptr)); // 将指针插入map中

    // 在map中释放动态分配的内存
    for (auto it = my_map.begin(); it != my_map.end(); ++it) {
        delete it->second;
        it->second = nullptr;
    }

    return 0;
}

六、map.insert数组

map.insert函数还支持一次性插入一个数组,代码如下:


#include 
#include 

int main()
{
    std::map my_map;

    std::pair arr[] = {{1, 'a'}, {2, 'b'}};
    my_map.insert(arr, arr + sizeof(arr) / sizeof(arr[0]));

    return 0;
}

七、map.insert 红黑树异常

由于map插入时需要保证键值唯一,因此map底层使用红黑树来实现,如果插入造成非法操作,会引发红黑树异常。


#include 
#include 

int main()
{
    std::map my_map = {{1, 'a'}, {3, 'c'}};

    try {
        my_map.insert(std::pair(2, 'b')); // 插入造成红黑树异常
    }
    catch (const std::exception& e) {
        std::cout << "Exception caught : " << e.what() << std::endl;
    }

    return 0;
}

八、map.insert(make_pair)

使用std::make_pair()也可以进行插入元素,下面是使用make_pair插入元素的代码:


#include 
#include 

int main()
{
    std::map my_map;

    my_map.insert(std::make_pair(1, 'a')); // 使用make_pair插入元素

    return 0;
}

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT