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

std::bad_array_new_length

Материал из 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++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
 
 
Определено в заголовочном файле <new>
class bad_array_new_length;
(начиная с C++11)

std::bad_array_new_length это тип объекта, выбрасываемого в качестве исключения выражениями new для сообщения о недопустимой длине массива, если

  1. Длина массива отрицательна,
  2. Общий размер нового массива превышает максимальное значение, определённое реализацией,
  3. Количество предложений-инициализаторов превышает количество элементов для инициализации.

Только первое измерение массива может генерировать это исключение; измерения, отличные от первого, являются константными выражениями и проверяются во время компиляции.

cpp/error/exceptioncpp/memory/new/bad allocstd-bad array new length-inheritance.svg

Диаграмма наследования

Содержание

[править]Функции-элементы

(конструктор)
создаёт новый объект bad_array_new_length
(public функция-элемент)
operator=
заменяет объект bad_array_new_length
(public функция-элемент)
what
возвращает пояснительную строку
(public функция-элемент)

std::bad_array_new_length::bad_array_new_length

bad_array_new_length()noexcept;
(1) (начиная с C++11)
bad_array_new_length(const bad_array_new_length& other )noexcept;
(2) (начиная с C++11)

Создаёт новый объект bad_array_new_length с определённой реализацией строкой байтов, заканчивающейся нулём, которая доступна через what().

1) Конструктор по умолчанию.
2) Конструктор копирования. Если *this и other имеют динамический тип std::bad_array_new_length, тогда std::strcmp(what(), other.what())==0.

Параметры

other другой объект исключения для копирования

std::bad_array_new_length::operator=

bad_array_new_length& operator=(const bad_array_new_length& other )noexcept;
(начиная с C++11)

Присваивает содержимое содержимому other. Если *this и other имеют динамический тип std::bad_array_new_length, тогда std::strcmp(what(), other.what())==0 после присваивания.

Параметры

other другой объект исключения для присваивания

Возвращаемое значение

*this

std::bad_array_new_length::what

virtualconstchar* what()constnoexcept;
(начиная с C++11)

Возвращает пояснительную строку.

Параметры

(нет)

Возвращаемое значение

Указатель на завершающуюся нулём строку с пояснительной информацией. Строка подходит для преобразования и отображения в виде std::wstring. Указатель гарантированно действителен, по крайней мере, до тех пор, пока объект исключения, из которого он получен, не будет уничтожен или пока не будет вызвана неконстантная функция-элемент (например, оператор присваивания копированием) для объекта исключения.

Примечание

Реализации могут, но не обязаны переопределять what().

Унаследован от std::bad_alloc

Унаследован от std::exception

Функции-элементы

уничтожает объект исключения
(virtual public of std::exception функция-элемент)[править]
[virtual]
возвращает поясняющую строку
(virtual public of std::exception функция-элемент)[править]

[править]Пример

Три условия, при которых std::bad_array_new_length должно быть сгенерировано:

#include <climits>#include <iostream>#include <new>   int main(){try{int negative =-1; new int[negative];}catch(const std::bad_array_new_length&e){std::cout<<"1) "<< e.what()<<": отрицательный размер\n";}   try{int small =1; new int[small]{1,2,3};}catch(const std::bad_array_new_length&e){std::cout<<"2) "<< e.what()<<": слишком много инициализаторов\n";}   try{long large =LONG_MAX; new int[large][1000];}catch(const std::bad_array_new_length&e){std::cout<<"3) "<< e.what()<<": слишком большой\n";}   std::cout<<"Конец\n";}

Возможный вывод:

1) std::bad_array_new_length: отрицательный размер 2) std::bad_array_new_length: слишком много инициализаторов 3) std::bad_array_new_length: слишком большой Конец

[править]Смотрите также

функции распределения памяти
(функция)[править]
исключение генерируемое при сбое выделения памяти
(класс)[править]
close