std::ignore
来自 cppreference.cn
定义于头文件 <tuple> |
||
定义于头文件 <utility> |
||
(1) | ||
const /*ignore-type*/ ignore; |
(since C++11) (until C++14) |
|
constexpr /*ignore-type*/ ignore; |
(since C++14) (inline since c++17) |
|
(2) | ||
struct /*ignore-type*/ { |
(since C++11) (until C++14) (exposition only*) |
|
struct /*ignore-type*/ { |
(since C++14) (exposition only*) |
|
1) 一个对象,任何值都可以赋值给它而无效。
2) std::ignore 的类型。
目录 |
[编辑] 注解
void 表达式或 volatile 位域值不能赋值给 std::ignore。
std::ignore 旨在与 std::tie 一起使用,在解包 std::tuple 时,作为不使用的参数的占位符,但可以用于任何不需要的赋值。
一些代码指南建议使用 std::ignore 以避免来自 [[nodiscard]] 函数的未使用返回值警告,即使不需要赋值。
对于忽略不需要赋值的值,可以转换为 void。对于有名称但其值未使用的变量,可以将它们转换为 void 或使用 [[maybe_unused]]
声明这些变量。
[编辑] 示例
- 演示了 std::ignore 与 [[nodiscard]] 函数一起使用。
- 解包 std::pair<iterator, bool> returned by 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) |
创建左值引用元组或将元组解包为单个对象 (函数模板) |