std::unique_ptr<std::array<T,N是否有用例>>
Is there a use case for std::unique_ptr<std::array<T,N>>
我遇到了类似的东西:
using arr_t=std::array<std::array<std::array<int,1000>,1000>,1000>;
std::unique_ptr<arr_t> u_ptr;
显然,使用了独特的指针来克服堆叠量问题。是否有任何情况可以使用以前的代码,而不仅仅是使用std::vector
?std::unique_ptr<std::array<T,N>>
吗?
上面的代码生成了一个十亿个元素的连续缓冲区, []
访问可以使您可以作为3维1000个侧面的立方体获得元素。
矢量的向量将是一堆由指针和所有权语义连接的无连锁缓冲区。
我怀疑您建议您
using u_ptr=std::vector<std::array<std::array<int,1000>,1000>>;
然后将上述arr_t
调整为1000
一旦创建。这在手柄对象中具有额外的2个指针开销的适度成本。它还允许尺寸变化,这意味着确保其固定大小按预期是用户代码必须确保的东西。您需要 block 一堆方法,基本上所有unique_ptr
都没有暴露,以确保安全或审核您的代码不使用它们。
其中一些操作可能非常昂贵;.push_back({})
将重新分配一个千兆字节。
现在,也许您打算永远不会称呼它;但是,如果您具有处理向量的通用代码,则必须审核其中的所有,以确保所有操作都不执行这些操作。在此时,如果没有滚动式跨度级别的情况,则无法对vector
进行非const句柄。
我们可以阻止我们不想用私有继承和using
语句展示的方法,但是此时,我们最终完成了大部分工作以返回unique_ptr
解决方案。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 是std :: set&lt; std :: future&gt;不可能存在
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- 使用 std::vector<boost::shared_ptr<Base_Class>> 或 boost::p tr_vector 的性能注意事项是什么<Base>
- std::map<std::set, double> AND std:<long>map< std::p air<long, long>, double>
- 如何获取std::vector<DMatch>