草庐IT

延时分配

全部标签

c++ - std::shared_ptr 预分配内存

我想在一个堆请求(如std::make_shared)中为shared_ptr的控制block和value_type预分配内存,但是不要立即在其中构造任何对象。当我实际需要构造对象时,使用放置new。可能吗?std::make_shared或std::allocate_shared似乎都无法解决我的问题。 最佳答案 我建议创建延迟初始化包装类,它本身包含足够的内存供您稍后要初始化的对象使用。这个包装器甚至可以有特殊的方法来在析构函数中调用placementnew和delete初始化对象。

c++ - 为维数增加(点数)的点云分配 CUDA 设备内存

我正在编写一个程序,我需要:对图像的每个像素进行测试如果测试结果为真,我必须向点云中添加一个点如果测试结果为假,什么都不做我已经在CPU端C++上编写了一个工作代码。现在我需要使用CUDA加速它。我的想法是让一些block/线程(我猜是每个像素一个线程)并行执行测试,如果测试结果为真,则让线程向云中添加一个点。我的麻烦来了:如果我事先不知道要插入到点云中的点数,我如何在设备内存中为点云分配空间(使用cudaMalloc或类似工具)?我是否必须分配固定数量的内存,然后在每次点云达到限制维度时增加它?还是有一种“动态”分配内存的方法? 最佳答案

c++ - 允许将类分配为零

我正在编写一个模板函数,我想将一个模板变量初始化为零。我正在考虑将变量设置为零,然后让类类型定义自己的“零”定义:Tdata=0;我尝试重载赋值运算符:classExample{public:intdata;Example(){}Example&operator=(intv){data=v;return*this;}};templateTtest(){Tdata=0;returndata;}intmain(intargc,char**argv){doublev1=test();Examplev2=test();return1;}...但是编译器给我“错误:从'int'到非标量类型的转换

c++ - 了解具有动态内存分配的二维数组

谁能帮我理解这段代码的最后一行?我不明白它是如何动态分配二维数组的。我知道在第6行,它创建了一个名为“a”的指针,并将其指向由“c”定义的大小为5的整数数组。我不明白的是“newint”语句是如何与等式中的r一起工作的。提前致谢。#includeconstintc=5;//numofcolumnsintmain(){intr=5;int(*a)[c];a=newint[r][c];//allocatearray} 最佳答案 如果你有一个类型T并且要分配一个大小为N的数组,那么这个表达式newT[N]返回分配数组的第一个元素的T*类型

c++ - 如何将自定义分配器的完全相同状态传递给多个容器?

我正在编写一个分配器,它引用了某个类的另一个实例,该类跟踪分配的字节数。下面是我正在尝试做的事情的一个最小示例(改编自here),只是没有整个内存跟踪类,而是我引用了一些收集到目前为止分配的字节的int。此引用在main内部分配,应传递给CustomAllocator:#include//numeric_limits#include#include//typeid//container#include#include#includetemplateclassCustomAllocator{public://typedefinitionstypedefTvalue_type;/**Ele

c++ - 分配在堆上的数据是否比分配在堆栈上的数据访问速度慢?

我听到过关于这个问题的不同意见。有人说访问分配在堆上的数据(即std::vector或通过malloc分配的动态数组)总是比访问分配在堆栈上的数据慢一点,因为进程必须始终通过中间指针来访问该数据,该数据可能位于完全不同的内存区域;另一方面,他们认为,访问分配在堆栈上的数据不需要通过这个中间指针,而且这些数据很可能已经缓存了。其他人声称只有数据的分配在堆上比在栈上慢(因为malloc、mmap和类似函数的开销),但是访问是不是,除非堆栈和堆位于不同的物理驱动器上。什么是真相? 最佳答案 事实(至少在大多数现代cpu上)是堆栈和堆的性能

c++ - std::allocate_shared,允许从自定义分配器和单次分配中分配共享指针引用计数

Makeshared使用引用计数和对象的单一分配提高性能,是否可以将自定义分配器与std::allocate_shared一起使用并且仍然有一个分配,根据我写的测试代码它没有发生:sample我知道boost::intrusive,但它有额外的代码需要编写并且可能出错 最佳答案 在一些调试的帮助下发现std::allocate_shared做了预期的事情,它允许你只为你的对象和引用计数器进行一次分配。下面是更正后的代码:allocateshared此处operatornew对std::make_shared和std::allocat

c++ - 内存分配导致内存泄漏

c++的关于这个问题,我还有一个问题。回答者说第一个des=newchar[src.size()+1];会导致内存泄漏,因为des是一个局部变量,所以他随后建议了另一种方法。char*toNormalWord(conststd::string&src){char*des=newchar[src.size()+1];//stuffreturndes;}但是我不明白为什么局部变量会导致内存泄漏,第一个和第二个有什么区别。第二个不也是用des作为函数中的局部变量吗?我认为不同之处在于函数接收des作为参数或者只是创建它们自己。我想我不知道一些重要的事情,但我不知道那是什么......

c++ - 在数组 dna 中的每个对象中获取相同的字符串(基因数组)(动态分配)

我创建了一个名为DNA的类,它有一个无参数构造函数和两个成员函数,即initialize()和show()。问题是当我创建一个使用new运算符的数组并使用for循环调用每个对象的初始化函数,而不是在成员变量“genes”中获取不同的字符串,我在每个对象的基因中获取完全相同的字符集(数组)阵列。尽管我在字符串初始化之前对srand()函数进行了播种,但没有看到任何效果。下面的代码。#include#include#include#includeusingnamespacestd;stringsampleSpace("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghij

c++ - 在 "Modern C++ Design"/Loki 中找到的小对象分配器是否已被弃用以支持更新的实现?

看来代码和书已经沦为现代C++运动的基础,不再更新了。在Boost或TR1中是否有某种替代品? 最佳答案 查看Boost.Pool图书馆。 关于c++-在"ModernC++Design"/Loki中找到的小对象分配器是否已被弃用以支持更新的实现?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2443165/