命名空间
变体
操作

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

来自 cppreference.cn
< cpp‎ | container‎ | queue
template< class... Args >
void emplace( Args&&... args );
(since C++11)
(until C++17)
template< class... Args >
decltype(auto) emplace( Args&&... args );
(since C++17)

将新元素推到队列的末尾。元素被就地构造,即不执行复制或移动操作。元素的构造函数使用与提供给函数的参数完全相同的参数调用。

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

目录

[编辑] 参数

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

[编辑] 返回值

(无)

(until C++17)

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

(since 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)

[编辑] 参见

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