std::ignore
来自 cppreference.com
定义在头文件 <tuple> 中 |
||
定义在头文件 <utility> 中 |
||
(1) | ||
const /*ignore-type*/ ignore; |
(自 C++11 起) (直到 C++14) |
|
constexpr /*ignore-type*/ ignore; |
(自 C++14 起) (自 c++17 起为内联) |
|
(2) | ||
struct /*ignore-type*/ { |
(自 C++11 起) (直到 C++14) (仅供说明*) |
|
struct /*ignore-type*/ { |
(自 C++14 起) (仅供说明*) |
|
1) 一个对象,任何值都可以分配给它,没有任何效果。
2)
std::ignore
的类型。内容 |
[编辑] 注意
一个 void 表达式或一个 volatile 位域值不能分配给 std::ignore
。
std::ignore
最初旨在与 std::tie 一起使用,用于解包一个 std::tuple,作为未使用的参数的占位符。
一些代码指南建议使用 std::ignore
来避免来自 [[nodiscard]]
函数的未使用返回值的警告。
[编辑] 示例
- 演示了
std::ignore
与[[nodiscard]]
函数一起使用。 - 解包由 std::pair<iterator, bool> 返回的 std::set::insert(),但只保存布尔值。
运行此代码
#include <iostream> #include <set> #include <string> #include <tuple> [[nodiscard]] int dontIgnoreMe() { return 42; } int main() { std::ignore = dontIgnoreMe(); std::set<std::string> set_of_str; if (bool inserted{false}; std::tie(std::ignore, inserted) = set_of_str.insert("Test"), inserted) std::cout << "Value was inserted successfully.\n"; }
输出
Value was inserted successfully.
[编辑] 缺陷报告
以下行为变更缺陷报告已追溯应用于先前发布的 C++ 标准。
DR | 应用于 | 已发布的行为 | 正确行为 |
---|---|---|---|
LWG 2773 | C++14 | std::tuple 被设置为 constexpr 但 std::ignore 尚未 |
设置为 constexpr |
P2968R2 | C++11 | std::ignore 在 std::tie 之外的行为没有正式指定 |
完全指定 |
[编辑] 参见
(C++11) |
创建一个左值引用的 tuple 或将一个 tuple 解包到单个对象中 (函数模板) |