Header der Standardbibliothek <new>
Aus cppreference.com
Diese Headerdatei ist Teil der Bibilothek zur dynamischen Speicherverwaltung, die insbesondere Funktionen zur machinennahen Speicherverwaltung beinhaltet.
Klassen | ||
Ausnahme bei Fehlschlag der Speicherzuweisung (Klasse) | ||
(C++11) |
Ausnahme bei ungültiger Arraylänge bei der Zuweisung (Klasse) | |
Marker, um eine Allokationsfunktion auszuwählen, die keine Ausnahmen auslöst (Klasse) | ||
(C++17) |
Typ, um Alignment an Allokations- und Deallokationsfunktionen zu übergeben, die dieses berücksichtigen (enum) | |
(C++20) |
Marker, um destroying-delete Überladungen von delete zu identifizieren (Klasse) | |
Typen | ||
Typ des Funktionszeiger für new (typedef) | ||
Konstanten | ||
ein Objekt vom Typ nothrow_t zur Verwendung bei der Auswahl einer Allokationsfunktion, die keine Ausnahmen auslöst. (konstanten) | ||
minimaler Offset, um falsches Teilen zu vermeiden maximaler Offset, um richtiges Teilen zu begünstigen (konstanten) | ||
Funktionen | ||
Speicheranforderungsfunktion (Funktion) | ||
Speicherfreigabefunktion (Funktion) | ||
(C++11) |
gibt den aktuellen Funktionszeiger auf die Allokationsfunktion zurück (Funktion) | |
registriert einen neuen Funktionszeiger auf die Allokationsfunktion (Funktion) | ||
(C++17) |
Optimisierungsschranke für Zeiger (Funktions-Template) |
[Bearbeiten] Inhaltsübersicht
namespace std { // storage allocation errors class bad_alloc; class bad_array_new_length; struct destroying_delete_t { explicit destroying_delete_t() = default; }; inline constexpr destroying_delete_t destroying_delete{}; // global operator new control enum class align_val_t : size_t {}; struct nothrow_t { explicit nothrow_t() = default; }; extern const nothrow_t nothrow; using new_handler = void (*)(); new_handler get_new_handler() noexcept; new_handler set_new_handler(new_handler new_p) noexcept; // pointer optimization barrier template<class T> [[nodiscard]] constexpr T* launder(T* p) noexcept; // hardware interference size inline constexpr size_t hardware_destructive_interference_size = /* implementation-defined */; inline constexpr size_t hardware_constructive_interference_size = /* implementation-defined */; } // storage allocation and deallocation [[nodiscard]] void* operator new(std::size_t size); [[nodiscard]] void* operator new(std::size_t size, std::align_val_t alignment); [[nodiscard]] void* operator new(std::size_t size, const std::nothrow_t&) noexcept; [[nodiscard]] void* operator new(std::size_t size, std::align_val_t alignment, const std::nothrow_t&) noexcept; void operator delete(void* ptr) noexcept; void operator delete(void* ptr, std::size_t size) noexcept; void operator delete(void* ptr, std::align_val_t alignment) noexcept; void operator delete(void* ptr, std::size_t size, std::align_val_t alignment) noexcept; void operator delete(void* ptr, const std::nothrow_t&) noexcept; void operator delete(void* ptr, std::align_val_t alignment, const std::nothrow_t&) noexcept; [[nodiscard]] void* operator new[](std::size_t size); [[nodiscard]] void* operator new[](std::size_t size, std::align_val_t alignment); [[nodiscard]] void* operator new[](std::size_t size, const std::nothrow_t&) noexcept; [[nodiscard]] void* operator new[](std::size_t size, std::align_val_t alignment, const std::nothrow_t&) noexcept; void operator delete[](void* ptr) noexcept; void operator delete[](void* ptr, std::size_t size) noexcept; void operator delete[](void* ptr, std::align_val_t alignment) noexcept; void operator delete[](void* ptr, std::size_t size, std::align_val_t alignment) noexcept; void operator delete[](void* ptr, const std::nothrow_t&) noexcept; void operator delete[](void* ptr, std::align_val_t alignment, const std::nothrow_t&) noexcept; [[nodiscard]] void* operator new (std::size_t size, void* ptr) noexcept; [[nodiscard]] void* operator new[](std::size_t size, void* ptr) noexcept; void operator delete (void* ptr, void*) noexcept; void operator delete[](void* ptr, void*) noexcept;