国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構

            手機站
            千鋒教育

            千鋒學習站 | 隨時隨地免費學

            千鋒教育

            掃一掃進入千鋒手機站

            領取全套視頻
            千鋒教育

            關注千鋒學習站小程序
            隨時隨地免費學習課程

            當前位置:首頁  >  技術干貨  > 詳解map.insert()

            詳解map.insert()

            來源:千鋒教育
            發(fā)布人: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 異常

            在插入元素時,可能會發(fā)生重復插入的情況,此時會返回一個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函數(shù)的返回值為一個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()內(nèi)存泄漏

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

            
            #include 
            #include 
            
            int main()
            {
                std::map my_map;
            
                char* ptr = new char('a'); // 動態(tài)分配內(nèi)存
                my_map.insert(std::make_pair(1, ptr)); // 將指針插入map中
            
                // 在map中釋放動態(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ù)還支持一次性插入一個數(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插入時需要保證鍵值唯一,因此map底層使用紅黑樹來實現(xiàn),如果插入造成非法操作,會引發(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()也可以進行插入元素,下面是使用make_pair插入元素的代碼:

            
            #include 
            #include 
            
            int main()
            {
                std::map my_map;
            
                my_map.insert(std::make_pair(1, 'a')); // 使用make_pair插入元素
            
                return 0;
            }
            

            聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您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