【C++】[]操作符和insert函数来插入元素的区别和适合场景

在C++的std::map中,可以使用[]操作符和insert函数来插入元素,它们之间有一些区别:

[]操作符:

使用[]操作符可以直接通过键值对的形式插入元素,如果键已经存在,则会更新对应的值;

如果键不存在,则会插入一个新的键值对,并将值初始化为该类型的默认值;

返回值为对应键的引用,可以直接修改键对应的值。

cpp 复制代码
std::map<std::string, int> myMap;
myMap["apple"] = 3; // 插入或更新键为"apple"的值为3
cpp 复制代码
std::map<std::string, int> myMap;
int& value = myMap["apple"]; // 获取或插入键为"apple"的值,并返回引用
value = 10; // 直接修改"apple"对应的值为10

insert函数:

insert函数接受一个std::pair类型的参数,其中包含要插入的键值对;

如果键已经存在,则插入操作不会生效,保持map原有内容不变;

返回一个std::pair类型的迭代器,指向插入的元素或已存在的元素。

cpp 复制代码
std::map<std::string, int> myMap;
myMap.insert(std::make_pair("apple", 3)); // 插入键为"apple",值为3的元素
cpp 复制代码
std::map<std::string, int> myMap;
std::pair<std::map<std::string, int>::iterator, bool> result = myMap.insert(std::make_pair("apple", 5));

if (result.second) {
    // 插入成功,result.first 指向插入的元素
} else {
    // 插入失败,result.first 指向已存在的元素
}

总的来说,使用[]操作符简单直接,适合于直接修改元素的值;而insert函数更加灵活,可以控制插入操作的行为,避免重复插入相同的键。

对于使用[]操作符和insert函数插入元素的选择,可以根据以下场景进行区分:

使用[]操作符的场景:

  • 更新已存在键的值:如果需要更新已存在键对应的值,使用[]操作符是最直观和简单的方式。
  • 快速插入新键值对:对于直接插入新键值对,并且不关心是否已存在相同键的情况,[]操作符更加便捷。

使用insert函数的场景:

  • 避免重复插入相同的键:如果需要确保不会重复插入相同的键,可以使用insert函数进行插入操作。
  • 需要获取插入结果:通过insert函数可以获取插入操作的结果,方便进一步处理。

示例场景:

使用[]操作符:在一个计数器中,需要统计每个字符出现的次数。可以使用[]操作符直接访问和更新字符的计数。

cpp 复制代码
std::map<char, int> charCount;
char c = 'a';
charCount[c]++; // 增加字符'a'的计数

使用insert函数:在一个配置管理器中,需要插入新的配置项,但要确保不会重复插入相同的配置键。

cpp 复制代码
std::map<std::string, std::string> configMap;
std::pair<std::string, std::string> newConfig("key", "value");
auto result = configMap.insert(newConfig);
if (result.second) {
    // 插入成功
} else {
    // 配置键已存在
}

根据具体需求和要求,在不同的情况下选择合适的插入方式可以使代码更清晰、高效地实现预期功能。

相关推荐
yblackd几秒前
UnrealEngine Win风格 窗口选择打开文件
c++·ue5·虚幻
橘色的喵2 分钟前
C++17 vs C 编译产物体积:工业嵌入式场景的实测与分析
c语言·c++·c++17
一 乐3 分钟前
健身房预约|基于java+ vue健身房预约小程序系统(源码+数据库+文档)
java·vue.js·spring boot·小程序·论文·毕设·健身房预约小程序
望舒51317 分钟前
代码随想录day32,动态规划part1
java·算法·leetcode·动态规划
楠秋92019 分钟前
代码随想录算法训练营第三十二天| 509. 斐波那契数 、 70. 爬楼梯 、746. 使用最小花费爬楼梯
数据结构·算法·leetcode·动态规划
㓗冽20 分钟前
最大效益(二维数组)-基础题76th + 螺旋方阵(二维数组)-基础题77th + 方块转换(二维数组)-基础题78th
数据结构·算法
Ivanqhz23 分钟前
数据流分析的核心格(Lattice)系统
开发语言·javascript·后端·python·算法·蓝桥杯·rust
麻辣香蝈蝈25 分钟前
【入门】职场如何沟通以及开发一个功能
java
he___H26 分钟前
jvm41-47回
java·开发语言·jvm
琛説27 分钟前
⚡PitchPPT:将PPT导出为高清全图PPT,并控制PPT文件大小在固定MB/GB以内【解析算法原理 · 作者谈】
windows·python·算法·github·powerpoint