【C++容器】key相同的键值对插入map时的覆盖问题

map容器插入键值对的方法一般有两种

1. map["key"] = value;
2. map.insert(make_pair<>(key, value));

 

  • 使用方法一插入相同键的键值对时,后一组的键值对会覆盖(替换)前一组键值对。代码如下:
#include <map>
#include <iostream>

using namespace std;

int main()
{
  map<double, double> mp1;
  mp1[1.0] = 1.1;
  mp1[1.0] = 1.2;
  cout << mp1.size() << endl;
  cout << mp1.begin()->second << endl;
  return 0;
}

输出结果为:

1
1.2

 

  • 使用方法二插入相同键的键值对时,后一组的键值对不会插入map容器,即不会覆盖前一组键值对。代码如下:
#include <map>
#include <iostream>

using namespace std;

int main()
{
  map<double, double> mp1;
  mp1.insert(make_pair<double, double>(2.0, 2.1));
  mp1.insert(make_pair<double, double>(2.0, 2.2));
  cout << mp1.size() << endl;
  cout << mp1.begin()->second << endl;
  return 0;
}

输出结果为

1
2.1

 

 【说明】map在进行插入的时候是不允许有重复的键值的,如果新插入的键值与原有的键值重复则插入无效,可以通过insert的返回值来判断是否成功插入。下面是insert的函数原型:

pair<iterator, bool> insert(const value_type& x);

可以通过返回的pair中第二个bool型变量来判断是否插入成功。

 

上一篇:JdbcTemplate基础【项目demo】【基础知识】【简单明了,一眼就会】


下一篇:Spring的JdbcTemplate