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

std::nothrow

Материал из cppreference.com
< cpp | memory | new
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, 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)
 
Динамическое управление памятью
no section name
Ограниченные алгоритмы неинициализированной памяти
no section name
Поддержка сбора мусора
(C++11)(до C++23)
(C++11)(до C++23)
(C++11)(до C++23)
(C++11)(до C++23)
(C++11)(до C++23)
(C++11)(до C++23)



no section name
 
 
<tbody> </tbody> <tbody class="t-dcl-rev "> </tbody><tbody> </tbody>
Определено в заголовочном файле <new>
struct nothrow_t {};
(до C++11)
struct nothrow_t { explicit nothrow_t() = default; };
(начиная с C++11)
extern const std::nothrow_t nothrow;

std::nothrow_t это пустой классовый тип, используемый для устранения неоднозначности перегруженных функций выделения памяти генерирующих или нет исключения. std::nothrow является его константой.

Пример

#include <iostream>
#include <new>

int main()
{
    try
    {
        while (true)
        {
            new int[100000000ul];   // генерирующая перегрузка
        }
    }
    catch (const std::bad_alloc& e)
    {
        std::cout << e.what() << '\n';
    }

    while (true)
    {
        int* p = new(std::nothrow) int[100000000ul]; // не генерирующая перегрузка
        if (p == nullptr)
        {
            std::cout << "Распределение вернуло nullptr\n";
            break;
        }
    }
}

Вывод:

std::bad_alloc
Распределение вернуло nullptr

Отчёты о дефектах

Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:

Номер Применён Поведение в стандарте Корректное поведение
LWG 2510 C++11 конструктор по умолчанию был неявным, что могло привести к неоднозначности сделан явным

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

функции распределения памяти
(функция) [править]