C++
容器 | Containers

std::map::emplace

STD::MAP::Emplace

template< class... Args > std::pair emplace( Args&&... args (since C++11)

将一个新元素插入到在给定的容器中构造的容器中。args如果容器中没有带键的元素。

谨慎使用emplace允许构造新元素,同时避免不必要的复制或移动操作。新元素%28i.e的构造函数。std::pair<const Key, T>%29的调用参数与提供给emplace,通过std::forward<Args>(args)...即使容器中已经有一个带有密钥的元素,也可以构造该元素,在这种情况下,新构造的元素将立即被销毁。

没有迭代器或引用无效。

参数

args-arguments to forward to the constructor of the element

返回值

返回由迭代器组成的一对插入元素,如果没有插入,则返回已经存在的元素,并返回bool表示插入是否发生。插入为true,无插入为false。

例外

如果任何操作引发异常,则此函数没有任何效果。

复杂性

容器大小的对数。

二次

#include <iostream> #include <utility> #include <string> #include <map> int main() { std::map<std::string, std::string> m; // uses pair's move constructor m.emplace(std::make_pair(std::string("a"), std::string("a")) // uses pair's converting move constructor m.emplace(std::make_pair("b", "abcd") // uses pair's template constructor m.emplace("d", "ddd" // uses pair's piecewise constructor m.emplace(std::piecewise_construct, std::forward_as_tuple("c"), std::forward_as_tuple(10, 'c') // as of C++17, m.try_emplace("c", 10, 'c' can be used for (const auto &p : m) { std::cout << p.first << " => " << p.second << '\n'; } }

二次

产出:

二次

a => a b => abcd c => cccccccccc d => ddd

二次

另见

emplace_hint (C++11)constructs elements in-place using a hint (public member function)
try_emplace (C++17)inserts in-place if the key does not exist, does nothing if the key exists (public member function)
insertinserts elements or nodes (since C++17) (public member function)

© cppreference.com

在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。

http://en.cppreference.com/w/cpp/容器/map/emplace