命名空间
变体
操作

std::ignore

来自 cppreference.cn
< cpp‎ | utility‎ | tuple
 
 
 
 
定义于头文件 <tuple>
在头文件 <utility> 中定义
(1)
const /*ignore-type*/ ignore;
(C++11 起)
(until C++14)
constexpr /*ignore-type*/ ignore;
(C++14 起)
(inline since c++17)
(2)
struct /*ignore-type*/

{
    template< class T >
    const /*ignore-type*/& operator=( const T& ) const noexcept
    {
        return *this;
    }

};
(C++11 起)
(until C++14)
(仅作说明*)
struct /*ignore-type*/

{
    template< class T >
    constexpr const /*ignore-type*/& operator=( const T& ) const noexcept
    {
        return *this;
    }

};
(C++14 起)
(仅作说明*)
1) 一个对象,任何值都可以赋给它,没有副作用。
2) std::ignore 的类型。

目录

[编辑] 注意

一个 void 表达式或 volatile 位域值不能赋给 std::ignore

std::ignore 旨在与 std::tie 配合使用,当解包 std::tuple 时,作为未使用的参数的占位符,但它也可以用于任何不需要的赋值。

一些编码规范建议使用 std::ignore 来避免 nodiscard 函数的未使用返回值警告,尽管不要求赋值。

对于不需要赋值的值,可以将其强制转换为 void。对于有名称但其值未使用的变量,可以将其强制转换为 void 或使用 maybe_unused 声明这些变量。

[编辑] 示例

  1. 演示 std::ignorenodiscard 函数的使用。
  2. 解包 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++ 标准。

缺陷报告 应用于 发布时的行为 正确的行为
LWG 2773 C++14 std::tuple 已设为 constexpr,但 std::ignore 尚未 设为 constexpr
P2968R2 C++11 std::ignorestd::tie 之外的行为没有正式指定 已完全指定

[编辑] 参阅

(C++11)
创建左值引用 tuple 或将 tuple 解包为单独的对象
(函数模板) [编辑]