命名空间
变体
操作

std::queue<T,Container>::emplace

来自 cppreference.com
< cpp‎ | container‎ | queue
template< class... Args >
void emplace( Args&&... args );
(自 C++11 起)
(直到 C++17)
template< class... Args >
decltype(auto) emplace( Args&&... args );
(自 C++17 起)

将新元素推入队列末尾。元素是在原地构造的,即不执行任何复制或移动操作。元素的构造函数被调用,传递的参数与传递给函数的参数完全相同。

实际上调用 c.emplace_back(std::forward<Args>(args)...);.

内容

[编辑] 参数

args - 要转发到元素构造函数的参数

[编辑] 返回值

(无)

(直到 C++17)

上面对 Container::emplace_back 的调用的返回值或引用(如果有)。

(自 C++17 起)

[编辑] 复杂度

Container::emplace_back 的复杂度相同。

[编辑] 示例

#include <iostream>
#include <queue>
 
struct S
{
    int id;
 
    S(int i, double d, std::string s) : id{i}
    {
        std::cout << "S::S(" << i << ", " << d << ", \"" << s << "\");\n";
    }
};
 
int main()
{
    std::queue<S> queue;
    const S& s = queue.emplace(42, 3.14, "C++"); // for return value C++17 required
    std::cout << "id = " << s.id << '\n';
}

输出

S::S(42, 3.14, "C++")
id = 42

缺陷报告

以下更改行为的缺陷报告被追溯应用到以前发布的 C++ 标准。

DR 应用于 发布的行为 正确行为
LWG 2783 C++17 emplace 返回 reference,破坏了与 C++17 之前容器的兼容性 返回 decltype(auto)

[编辑] 另请参阅

在末尾插入元素
(公共成员函数) [编辑]
移除第一个元素
(公共成员函数) [编辑]