Namensräume
Varianten
Aktionen

std::pmr::null_memory_resource

Von cppreference.com
< cpp‎ | memory
 
 
Speicherverwaltungsbibliothek
(nur Exposition*)
Algorithmen für uninitialisierten Speicher
(C++17)
(C++17)
(C++17)
Beschränkte uninitialisierte
Speicher-Algorithmen
C-Bibliothek

Allocatoren
Speicherressourcen
pmr::null_memory_resource
(C++17)
Unterstützung für Garbage Collection
(C++11)(bis C++23)
(C++11)(bis C++23)
(C++11)(bis C++23)
(C++11)(bis C++23)
(C++11)(bis C++23)
(C++11)(bis C++23)
Uninitialisierter Speicher
Explizites Lebenszeitmanagement
 
Definiert in Header <memory_resource>
std::pmr::memory_resource* null_memory_resource() noexcept;
(seit C++17)

Gibt einen Zeiger auf eine memory_resource zurück, die keine Speicherzuweisung durchführt.

[bearbeiten] Rückgabewert

Gibt einen Zeiger p auf ein Objekt mit statischer Speicherdauer zurück, das von std::pmr::memory_resource abgeleitet ist, mit den folgenden Eigenschaften:

  • seine allocate() Funktion wirft immer std::bad_alloc;
  • seine deallocate() Funktion hat keine Auswirkung;
  • für jede memory_resource r gibt p->is_equal(r) zurück &r == p.

Bei jedem Aufruf dieser Funktion wird derselbe Wert zurückgegeben.

[bearbeiten] Beispiel

Das Programm demonstriert die Hauptanwendung von null_memory_resource: Sicherstellen, dass ein Speicherpool, der Speicher auf dem Stack benötigt, KEINEN Speicher auf dem Heap zuweist, wenn er mehr Speicher benötigt.

#include <array>
#include <cstddef>
#include <iostream>
#include <memory_resource>
#include <string>
#include <unordered_map>
 
int main()
{
    // allocate memory on the stack
    std::array<std::byte, 20000> buf;
 
    // without fallback memory allocation on heap
    std::pmr::monotonic_buffer_resource pool{buf.data(), buf.size(),
                                             std::pmr::null_memory_resource()};
 
    // allocate too much memory
    std::pmr::unordered_map<long, std::pmr::string> coll{&pool};
    try
    {
        for (std::size_t i = 0; i < buf.size(); ++i)
        {
            coll.emplace(i, "just a string with number " + std::to_string(i));
 
            if (i && i % 50 == 0)
                std::clog << "size: " << i << "...\n";
        }
    }
    catch (const std::bad_alloc& e)
    {
        std::cerr << e.what() << '\n';
    }
 
    std::cout << "size: " << coll.size() << '\n';
}

Mögliche Ausgabe

size: 50...
size: 100...
size: 150...
std::bad_alloc
size: 183