命名空间
变体
操作

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

来自 cppreference.com
< cpp‎ | container‎ | stack
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 <stack>
 
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::stack<S> stack;
    const S& s = stack.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)

[编辑] 参见

将元素插入栈顶
(公有成员函数) [编辑]
删除栈顶元素
(公有成员函数) [编辑]