草庐IT

延时分配

全部标签

c++ - 尝试动态内存分配 C++

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭4年前。Improvethisquestion我试图通过使用指针精确地分配1KiB的内存GetProcessMemoryInfo(GetCurrentProcess(),&pmc,sizeof(pmc));std::cout问题是每次我运行这段代码时它似乎分配100KiB到400KiB之间的任何地方我使用char因为它的大小是1个字节

c++ - 聪明地处理 vector 内存分配

假设我必须迭代一个可能非常大的数字vector,并将偶数和奇数元素复制到新的、单独的vector中。(源vector的偶数与奇数的比例可以是任意的;它可以是全偶数、全奇数或介于两者之间。)为简单起见,push_back通常用于此类事情:for(std::size_tIndex;Index但是,我担心如果将其用作排序算法等性能至关重要的实现的一部分,这将是低效且有害的。例如,快速排序涉及像这样分离元素。您可以使用reserve()预先分配内存,因此只需要一次分配,但随后您必须遍历整个源vector两次-一次计算需要多少元素进行整理,并再次进行实际复制。当然,您可以分配与源vector大小

c++ - 分配的数组已归零

在C++11中,当我使用T*array=newT[n];分配一个动态数组时,它已经归零(使用gcc4.7.2,Ubuntu12.1064位)。这是C++11规范强制要求的吗?如何在不清零元素的情况下分配数组?这应该会快一点。编辑:我已经检查过T=int。gcccxx-flags:-std=gnu++11-O3-ffast-math-fno-rtti 最佳答案 §5.3.4Ifthenew-initializerisomitted,theobjectisdefault-initialized(8.5);ifnoinitializati

c++ - 如何将 typedef 变量分配为静态

谁能告诉我下面程序中的错误。#includeusingnamespacestd;classA{public:typedefintcount;staticcountcnt;};countA::cnt=0;intmain(){return0;}错误计数没有命名类型 最佳答案 您必须使用A::countA::cnt=0;,因为您的typedef是在类A的范围内定义的。即要么将typedef移到类之外,要么像上面那样使用范围解析。 关于c++-如何将typedef变量分配为静态,我们在Stack

c++ - std::vector 的替代方案,因为重新分配会使指向元素的指针无效

这可能是一个新问题(我是),但我已经尽可能多地搜索以找到以下问题的解决方案我有以下场景(当然是经过大量提炼的):classContainer{std::vectorobj;};classPointers{std::vectorobj_ptr;};我有一个例程,将Object类型的元素推回Container中的vectorobj,然后将指向同一元素的指针推回obj_ptr。总体思路是obj_ptr[i]==&obj[i]贯穿程序的整个生命周期。我遇到的问题是,每当obj的容量需要增加时,所有指针都会失效,从而使obj_ptr完全无用。我已经尝试过使用最大预期大小(大约10^7)的obj.

c++ - 为什么我看到在堆和堆栈上分配的数组之间存在不同的行为?

我正在检查C++中两个二维数组的行为,一个从堆栈分配,一个从堆分配。我创建了两个相同形状的二维数组,并用一些数据填充这些数组。然后我尝试用两种不同的方法读取数组,第一种是使用简单的数组索引格式“Arr[ROW][COLUMN]”。然后我使用指针取消引用读取数组,我得到了堆分配数组的两个不同结果,但堆栈分配数组的结果相同。我试图理解为什么结果不同。如果有人可以提供任何说明,我将不胜感激。提前致谢。我正在运行的代码如下:#includeusingnamespacestd;intmain(){introws=6;intcolumns=3;//allocatefromthestack.doub

c++ - 在 C++ 中声明指向结构的指针会自动为其成员分配内存。我错了吗?

我编写了以下代码,我相信如果我试图访问我什至没有为其分配内存的结构的成员,它就会崩溃。但我很惊讶C++自动为结构分配内存。这是正常行为吗?相比之下,如果您声明一个指向对象的指针,然后尝试访问任何成员而没有使用运算符“new”实际创建对象,程序就会崩溃。我只是好奇为什么它会起作用,而我认为它不应该起作用。这是我的程序:#includestructProduto{intcodigo;floatpreco;};intmain(){structProduto*sabonete;sabonete->codigo=654321;sabonete->preco=0.85;printf("Codigo

c++ - 重新分配 C++ 数组的内存。

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:HowdoyoureallocinC++?我知道如果内存已通过malloc()或calloc()realloc()重新分配(扩展)C++数组。我的问题是,如何扩展C++中的数组,其内存已通过new运算符分配?

c++ - C++构造函数分配内存失败怎么办?

我刚遇到一个问题,类的构造函数需要分配内存。于是开心地写了char*mem=static_cast(malloc(100*sizeof(*mem)));.但后来我突然意识到,如果出现错误,我无法返回错误代码(我没有在我的代码中使用异常)。我该如何解决这个问题?我应该添加一个boolinitialized吗?成员,然后在完成我的类(class)之后,然后立即检查它,如:myClassmc;if(!mc.initialized){printf("Memoryallocationfailedinmc'sconstructor\n");exit(1);}谢谢,BodaCydo。

c++ - 新分配的 std::vector<int> 元素是否初始化为 0?

假设我们使用std::vector或std::vector.随着vector大小的增长,新分配的元素会被默认初始化为0,还是程序员需要显式地将它们初始化为0? 最佳答案 新元素是值初始化的:[C++11:23.3.6.3/9]:voidresize(size_typesz);Effects:Ifsz,equivalenttoerase(begin()+sz,end());.Ifsize(),appendssz-size()value-initializedelementstothesequence.对于int和long这意味着0:[