std::flat_map<Key,T,Compare,KeyContainer,MappedContainer>::replace
来自 cppreference.com
void replace( key_container_type&& key_cont, mapped_container_type&& mapped_cont ); |
(自 C++23 起) | |
替换底层容器 c
。等效于
c.keys = std::move(key_cont); c.values = std::move(mapped_cont);
必须满足以下条件
- 表达式 key_cont.size() == mapped_cont.size() 为 true,
- key_cont 中的元素根据
compare
进行排序,并且 - key_cont 不包含相等的元素。
否则,行为未定义。
内容 |
[编辑] 参数
keys_cont | - | 类型为 KeyContainer 的排序键容器,其内容将被移动到 *this 中 |
mapped_cont | - | 类型为 MappedContainer 的映射值容器,其内容将被移动到 *this 中 |
[编辑] 返回值
(无)
[编辑] 复杂度
等于应用于适配容器的 std::move 的复杂度。
[编辑] 示例
运行此代码
#include <algorithm> #include <cassert> #include <flat_map> #include <print> #include <vector> int main() { std::vector<int> keys{1, 2, 3}; assert(std::ranges::is_sorted(keys)); std::vector<double> values{2.2, 3.3, 1.1}; assert(keys.size() == values.size()); std::flat_map<int, double> map; assert(map.empty()); map.replace(keys, values); assert(map.size() == 3); assert(map.keys() == 3); assert(map.values() == 3); assert(keys.empty()); assert(values.empty()); std::println("{}", map); }
输出
{1: 2.2, 2: 3.3, 3: 1.1}
[编辑] 参见
提取底层容器 (公共成员函数) |