本文主要是介绍标准库标头 <memory_resource> (C++17)学习之monotonic_buffer_resource,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
类 std::pmr::monotonic_buffer_resource
是特定目的的内存资源类,它仅在销毁资源时释放分配的内存。它的意图是提供非常快速的内存分配,在内存用于分配少量对象,并于之后一次释放的情形。monotonic_buffer_resource
能以初始缓冲区构造,若无初始缓冲,或缓冲用尽,则从构造时提供的上游分配器分配缓冲区。缓冲区的大小以几何级数增长。monotonic_buffer_resource
不是线程安全的。
成员函数
(构造函数) | 构造一个 monotonic_buffer_resource (公开成员函数) |
(析构函数) [虚] | 销毁一个 monotonic_buffer_resource ,释放所有分配的内存(虚公开成员函数) |
operator= [弃置] | 复制赋值运算符被弃置。monotonic_buffer_resource 不可复制赋值(公开成员函数) |
公开成员函数 | |
release | 释放所有分配的内存 (公开成员函数) |
upstream_resource | 返回指向上游内存资源的指针 (公开成员函数) |
受保护成员函数 | |
do_allocate [虚] | 分配内存 (虚受保护成员函数) |
do_deallocate [虚] | 无操作 (虚受保护成员函数) |
do_is_equal [虚] | 与另一 std::pmr::memory_resource 比较相等性 (虚受保护成员函数) |
示例:
#include <array>
#include <chrono>
#include <cstddef>
#include <iomanip>
#include <iostream>
#include <list>
#include <memory_resource>template<typename Func>
auto benchmark(Func test_func, int iterations)
{const auto start = std::chrono::system_clock::now();while (iterations-- > 0)test_func();const auto stop = std::chrono::system_clock::now();const auto secs = std::chrono::duration<double>(stop - start);return secs.count();
}int main()
{constexpr int iterations{ 100 };constexpr int total_nodes{ 200000 };auto default_std_alloc = [total_nodes]{std::list<int> list;for (int i{}; i != total_nodes; ++i)list.push_back(i);};auto default_pmr_alloc = [total_nodes]{std::pmr::list<int> list;for (int i{}; i != total_nodes; ++i)list.push_back(i);};auto pmr_alloc_no_buf = [total_nodes]{std::pmr::monotonic_buffer_resource mbr;std::pmr::polymorphic_allocator<int> pa{ &mbr };std::pmr::list<int> list{ pa };for (int i{}; i != total_nodes; ++i)list.push_back(i);};//auto pmr_alloc_and_buf = [total_nodes]// {// std::array<std::byte, total_nodes * 32> buffer; // 足以适合所有节点// std::pmr::monotonic_buffer_resource mbr{ buffer.data(), buffer.size() };// std::pmr::polymorphic_allocator<int> pa{ &mbr };// std::pmr::list<int> list{ pa };// for (int i{}; i != total_nodes; ++i)// list.push_back(i);// };const double t1 = benchmark(default_std_alloc, iterations);const double t2 = benchmark(default_pmr_alloc, iterations);const double t3 = benchmark(pmr_alloc_no_buf, iterations);//const double t4 = benchmark(pmr_alloc_and_buf, iterations);std::cout << std::fixed << std::setprecision(3)<< "t1 (default std alloc): " << t1 << " sec; t1/t1: " << t1 / t1 << '\n'<< "t2 (default pmr alloc): " << t2 << " sec; t1/t2: " << t1 / t2 << '\n'<< "t3 (pmr alloc no buf): " << t3 << " sec; t1/t3: " << t1 / t3 << '\n';//<< "t4 (pmr alloc and buf): " << t4 << " sec; t1/t4: " << t1 / t4 << '\n';std::cout << "hello world\n";
}
运行结果:
参考:
std::pmr::monotonic_buffer_resource - cppreference.com
这篇关于标准库标头 <memory_resource> (C++17)学习之monotonic_buffer_resource的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!