千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 詳解map.insert()

詳解map.insert()

來源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-23 13:36:50 1700717810

一、map.insert用法

map.insert用于向一個(gè)map中插入一個(gè)元素,返回一個(gè)pair,第一個(gè)元素是插入元素的迭代器,第二個(gè)元素是一個(gè)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初始化

如果我們想要初始化一個(gè)map,可以使用以下代碼:


#include 
#include 

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

    return 0;
}

三、map.insert 異常

在插入元素時(shí),可能會(huì)發(fā)生重復(fù)插入的情況,此時(shí)會(huì)返回一個(gè)bool值表示插入是否成功。


#include 
#include 

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

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

    return 0;
}

四、map.insert返回值

map.insert函數(shù)的返回值為一個(gè)pair,第一個(gè)元素是插入元素的迭代器,第二個(gè)元素為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()內(nèi)存泄漏

在C++中,使用new關(guān)鍵字動(dòng)態(tài)分配內(nèi)存時(shí),需要手動(dòng)調(diào)用delete來釋放內(nèi)存,否則會(huì)造成內(nèi)存泄漏。在使用map.insert()插入指針時(shí),也需要注意內(nèi)存泄漏的問題。


#include 
#include 

int main()
{
    std::map my_map;

    char* ptr = new char('a'); // 動(dòng)態(tài)分配內(nèi)存
    my_map.insert(std::make_pair(1, ptr)); // 將指針插入map中

    // 在map中釋放動(dòng)態(tài)分配的內(nèi)存
    for (auto it = my_map.begin(); it != my_map.end(); ++it) {
        delete it->second;
        it->second = nullptr;
    }

    return 0;
}

六、map.insert數(shù)組

map.insert函數(shù)還支持一次性插入一個(gè)數(shù)組,代碼如下:


#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插入時(shí)需要保證鍵值唯一,因此map底層使用紅黑樹來實(shí)現(xiàn),如果插入造成非法操作,會(huì)引發(fā)紅黑樹異常。


#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()也可以進(jìn)行插入元素,下面是使用make_pair插入元素的代碼:


#include 
#include 

int main()
{
    std::map my_map;

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

    return 0;
}

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT