std:: bad_array_new_length
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Functions | ||||
|
(C++11)
|
||||
| Classes | ||||
|
bad_array_new_length
(C++11)
|
||||
|
(C++17)
|
||||
| Types | ||||
| Objects | ||||
|
(C++20)
|
||||
| Object access | ||||
|
(C++17)
|
|
Definiert im Header
<new>
|
||
|
class
bad_array_new_length
:
std::
bad_alloc
|
(seit C++11) | |
std::bad_array_new_length
ist der Typ des Objekts, das als Exception von den
new-expressions
geworfen wird, um ungültige Array-Längen zu melden, wenn
- Array-Länge ist negativ,
- Die Gesamtgröße des neuen Arrays würde den implementierungsdefinierten Maximalwert überschreiten,
- Die Anzahl der Initialisierer überschreitet die Anzahl der zu initialisierenden Elemente.
Nur die erste Array-Dimension kann diese Ausnahme generieren; andere Dimensionen als die erste sind konstante Ausdrücke und werden zur Kompilierzeit überprüft.
Vererbungsdiagramm
Inhaltsverzeichnis |
Memberfunktionen
|
(Konstruktor)
|
konstruiert ein neues
bad_array_new_length
Objekt
(öffentliche Elementfunktion) |
|
operator=
|
ersetzt das
bad_array_new_length
Objekt
(öffentliche Elementfunktion) |
|
what
|
gibt den erläuternden String zurück
(öffentliche Elementfunktion) |
std::bad_array_new_length:: bad_array_new_length
|
bad_array_new_length
(
)
noexcept
;
|
(1) |
(seit C++11)
(constexpr seit C++26) |
|
bad_array_new_length
(
const
bad_array_new_length
&
other
)
noexcept
;
|
(2) |
(seit C++11)
(constexpr seit C++26) |
Konstruiert ein neues
bad_array_new_length
-Objekt mit einer implementierungsdefinierten nullterminierten Byte-Zeichenkette, die über
what()
zugänglich ist.
std::bad_array_new_length
haben, dann gilt
std::
strcmp
(
what
(
)
, other.
what
(
)
)
==
0
.
Parameter
| other | - | ein weiteres Ausnahmeobjekt zum Kopieren |
std::bad_array_new_length:: operator=
|
bad_array_new_length
&
operator
=
(
const
bad_array_new_length
&
other
)
noexcept
;
|
(seit C++11)
(constexpr seit C++26) |
|
Weist die Inhalte mit denen von
other
zu. Wenn
*
this
und
other
beide den dynamischen Typ
std::bad_array_new_length
haben, dann ist
std::
strcmp
(
what
(
)
, other.
what
(
)
)
==
0
nach der Zuweisung.
Parameter
| other | - | ein weiteres Ausnahmeobjekt, mit dem zugewiesen wird |
Rückgabewert
* this
std::bad_array_new_length:: what
|
virtual
const
char
*
what
(
)
const
noexcept
;
|
(seit C++11)
(constexpr seit C++26) |
|
Gibt den erläuternden String zurück.
Rückgabewert
Zeiger auf einen implementierungsdefinierten nullterminierten String mit erläuternden Informationen. Der String ist geeignet für Konvertierung und Anzeige als std::wstring . Der Zeiger ist garantiert mindestens so lange gültig, bis das Ausnahmeobjekt, von dem er erhalten wurde, zerstört wird, oder bis eine nicht-konstante Memberfunktion (z.B. Kopierzuweisungsoperator) des Ausnahmeobjekts aufgerufen wird.
|
Der zurückgegebene String wird während der Konstantenauswertung mit der gewöhnlichen Literalkodierung kodiert. |
(seit C++26) |
Anmerkungen
Implementierungen dürfen, müssen aber nicht
what()
überschreiben.
Geerbt von std:: bad_alloc
Geerbt von std:: exception
Elementfunktionen
|
[virtual]
|
zerstört das Exception-Objekt
(virtuelle öffentliche Elementfunktion von
std::exception
)
|
|
[virtual]
|
gibt einen erklärenden String zurück
(virtuelle öffentliche Elementfunktion von
std::exception
)
|
Hinweise
| Feature-Test Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_constexpr_exceptions
|
202411L
|
(C++26) | constexpr für Ausnahmetypen |
Beispiel
Drei Bedingungen, unter denen
std::bad_array_new_length
ausgelöst werden sollte:
#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() << ": negative size\n"; } try { int small = 1; new int[small]{1,2,3}; } catch (const std::bad_array_new_length& e) { std::cout << "2) " << e.what() << ": too many initializers\n"; } try { long large = LONG_MAX; new int[large][1000]; } catch (const std::bad_array_new_length& e) { std::cout << "3) " << e.what() << ": too large\n"; } std::cout << "End\n"; }
Mögliche Ausgabe:
1) std::bad_array_new_length: negative size 2) std::bad_array_new_length: too many initializers 3) std::bad_array_new_length: too large End
Siehe auch
|
Allokierungsfunktionen
(Funktion) |
|
|
Ausnahme, die bei fehlgeschlagener Speicherallokation geworfen wird
(Klasse) |