命名空间
变体
操作

std::ignore

来自 cppreference.com
< cpp‎ | utility‎ | tuple
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库特性测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三向比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用实用程序
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中已弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型操作
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
通用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
基本字符串转换
(C++17)
(C++17)

 
 
定义在头文件 <tuple>
定义在头文件 <utility>
(1)
const /*ignore-type*/ ignore;
(自 C++11 起)
(直到 C++14)
constexpr /*ignore-type*/ ignore;
(自 C++14 起)
(自 c++17 起为内联)
(2)
struct /*ignore-type*/

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

};
(自 C++11 起)
(直到 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]] 函数的未使用返回值的警告。

[编辑] 示例

  1. 演示了 std::ignore[[nodiscard]] 函数一起使用。
  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++ 标准。

DR 应用于 已发布的行为 正确行为
LWG 2773 C++14 std::tuple 被设置为 constexprstd::ignore 尚未 设置为 constexpr
P2968R2 C++11 std::ignorestd::tie 之外的行为没有正式指定 完全指定

[编辑] 参见

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