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

std::pmr::null_memory_resource

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, 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++14)
(C++11)
(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
 
<tbody> </tbody>
Определено в заголовочном файле <memory_resource>
std::pmr::memory_resource* null_memory_resource() noexcept;
(начиная с C++17)

Возвращает указатель на memory_resource, который не выполняет никакого распределения.

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

Возвращает указатель p на объект статической длительности хранения типа, производного от std::pmr::memory_resource, со следующими свойствами:

  • его функция 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()
{
    // выделить память в стеке
    std::array<std::byte, 20000> buf;

    // без резервного выделения памяти в куче
    std::pmr::monotonic_buffer_resource pool{buf.data(), buf.size(),
                                             std::pmr::null_memory_resource()};

    // выделить слишком много памяти
    std::pmr::unordered_map<long, std::pmr::string> coll{&pool};
    try
    {
        for (std::size_t i = 0; i < buf.size(); ++i)
        {
            coll.emplace(i, "просто строка с номером " + std::to_string(i));

            if (i && i % 50 == 0)
                std::clog << "размер: " << i << "...\n";
        }
    }
    catch (const std::bad_alloc& e)
    {
        std::cerr << e.what() << '\n';
    }

    std::cout << "размер: " << coll.size() << '\n';
}

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

размер: 50...
размер: 100...
размер: 150...
std::bad_alloc
размер: 155