close
Пространства имён
Варианты
Действия

std::ignore

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(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)
 
 
<tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody>
Определено в заголовочном файле <tuple>
const /*не определено*/ ignore;
(начиная с C++11)
(до C++17)
inline constexpr /*не определено*/ ignore;
(начиная с C++17)

Объект неопределённого типа, которому можно присвоить любое значение без какого-либо эффекта. Предназначен для использования с std::tie при распаковке std::tuple в качестве заполнителя для неиспользуемых аргументов.

Хотя поведение std::ignore за пределами std::tie формально не указано, в некоторых руководствах по коду рекомендуется использовать std::ignore, чтобы избежать предупреждений о неиспользуемом возвращаемом значении функций [[nodiscard]].

Возможная реализация

namespace detail {
struct ignore_t {
    template <typename T>
    constexpr // требуется начиная с C++14
    void operator=(T&&) const noexcept {}
};
}
inline constexpr detail::ignore_t ignore; // 'const' только до C++17

Пример

  1. Демонстрирует использование std::ignore вместе с функцией [[nodiscard]].
  2. Распаковывает std::pair<iterator, bool>, возвращённый std::set::insert(), но сохраняет только логическое значение.
#include <iostream>
#include <string>
#include <set>
#include <tuple>

[[nodiscard]] int dontIgnoreMe()
{
    return 42;
}

int main()
{
    std::ignore = dontIgnoreMe();

    std::set<std::string> set_of_str;
    bool inserted = false;
    std::tie(std::ignore, inserted) = set_of_str.insert("Тест");
    if (inserted) {
        std::cout << "Значение успешно вставлено\n";
    }
}

Вывод:

Значение успешно вставлено

Смотрите также

создаёт std::tuple левосторонних ссылок или распаковывает кортеж на отдельные объекты
(шаблон функции) [править]