名前空間
変種
操作

std::pmr::null_memory_resource

From cppreference.com
< cpp‎ | memory
 
 
メモリ管理ライブラリ
(説明用*)
未初期化メモリのアルゴリズム
(C++17)
(C++17)
(C++17)
制約付き未初期化
メモリアルゴリズム
Cライブラリ

アロケータ
メモリリソース
pmr::null_memory_resource
(C++17)
ガベージコレクションのサポート
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
(C++11)(C++23まで)
未初期化ストレージ
(C++20まで*)
(C++20まで*)
明示的な生存期間管理
 
ヘッダ <memory_resource> で定義
std::pmr::memory_resource* null_memory_resource() noexcept;
(C++17以降)

一切のメモリ確保を行わないmemory_resourceへのポインタを返します。

[編集] 返り値

std::pmr::memory_resourceから派生した型で、静的記憶域期間を持つオブジェクトへのポインタpを返します。このオブジェクトは以下の特性を持ちます。

  • allocate()関数は常にstd::bad_allocを送出します。
  • deallocate()関数は何も行いません。
  • 任意のmemory_resource rに対して、p->is_equal(r)&r == pを返します。

この関数が呼び出されるたびに同じ値が返されます。

[編集]

このプログラムはnull_memory_resourceの主な使い方を示しています。スタック上にメモリを確保する必要があるメモリプールが、追加のメモリを必要とした場合にヒープ上にメモリを確保しないようにします。

#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';
}

実行結果の例

size: 50...
size: 100...
size: 150...
std::bad_alloc
size: 183
English 日本語 中文(简体) 中文(繁體)