草庐IT

allocation

全部标签

c++ - std::tr1::shared_ptr 是否会抛出 bad_alloc 并且在 try/catch block 中是个好主意?

我实际上正在制作一个简单的C++SFML游戏,我想学习更多关于C++编程的知识。现在我正在使用shared_ptr来管理资源。创建新资源时,我对shared_ptrs有一些疑问,例如:shared_ptrresource(newResource(World::LEVEL));根据boostshared_ptr(Y*p)throwsbad_alloc。我不知道std::tr1是否也这样做。而且我不知道我是否应该担心将shared_ptr放入try/catchblock中以检查是否抛出bad_alloc。这是一个好的编程习惯吗? 最佳答案

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

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

c++ - 在 C 中返回堆栈数据;它是否正确取消分配?

我在审查一位friend的代码时,就C/C++如何在堆栈上分配内存和管理其释放展开了一场有趣的辩论。如果我要在一个函数中创建一个包含10个对象的数组,但返回该数组,它是在函数弹出时释放(因此使给定数据无效)还是放入堆中(这引发了我们如何释放它?)。示例代码如下:Gene*GetTopTen(){//Create10genes(or10objects,doesn'tmatter)GeneTen[10];//SortoutexternalpooldataSort();//Copyoverdatatothearrayof10objectsfor(inti=0;i非常感谢任何帮助,这正在变成一

c++ - 线程构造的性能成本 : missed optimisations and memory allocation

我们遇到了一种奇怪的现象,其中包含头文件会导致某些内存分配密集型工作负载的性能下降5-10%。这个头文件将一个线程池声明为一个全局变量。该线程池从未在应用程序中以任何容量(还)使用过。也就是说,除了在程序启动时创建这个静态线程池外,应用程序完全是单线程的。一旦标题被移除,性能损失就会消失。从一些研究来看,由于某些编译器优化不再可能,多线程应用程序似乎会导致一些性能损失。每当以任何形式或容量实例化与线程相关的构造时,是否有可能关闭此类优化?或者,由于在执行大量内存分配时性能损失似乎最为明显,编译器是否有可能在编译/链接阶段意识到线程构造已实例化,因此它切换到线程安全内存分配器?这发生在L

c++ - C++中不同派生类的高效容器

在编写游戏程序时,我曾经将所有游戏对象存储在一个具有初始化和固定大小的std::vector中。最近我觉得需要在游戏对象类之间进行一些继承。让我们假设我有大约40个派生self的Enemy类的类。如果我想将这些类的对象/实例存储在vector中,我只能选择将它们存储为vectorEnemy*对吗?所以唯一连续分配的是指针,对吧?所以当需要取消引用时,我仍然会有很多缓存未命中,对吧?是否有任何“最佳实践”方式将派生类存储在连续分配的内存中,以便循环遍历它们花费最少的时间? 最佳答案 Boost刚刚为此目的接受了一个库:poly_col

c++ - 为什么我会收到 CL_MEM_OBJECT_ALLOCATION_FAILURE?

我在GPU上分配一个cl_mem缓冲区并对其进行处理,在超过一定尺寸之前效果很好。在那种情况下,分配本身会成功,但执行或复制不会。我确实想使用设备的内存来加快操作速度,所以我分配如下:buf=clCreateBuffer(cxGPUContext,CL_MEM_WRITE_ONLY,buf_size,NULL,&ciErrNum);现在我不明白的是大小限制。我正在复制大约16MB,但应该可以使用大约128MB(参见CL_DEVICE_MAX_MEM_ALLOC_SIZE)。为什么这些数字相差如此之大?这是oclDeviceQuery的一些摘录:CL_PLATFORM_NAME:NVID

c++ - 函数不会抛出 bad_alloc 异常

我正在尝试从Stroustrup的C++PL4书中做一个练习。任务是:Allocatesomuchmemoryusingnewthatbad_allocisthrown.Reporthowmuchmemorywasallocatedandhowmuchtimeittook.Dothistwice:oncenotwritingtotheallocatedmemoryandoncewritingtoeachelement.以下代码不会抛出std::bad_alloc异常。执行程序后,我在终端中收到消息“Killed”。还有。以下代码在~4秒后退出。但是当我取消注释内存使用消息时//++i;

C++ std::bad_alloc 错误

我正在开发C++程序(C++98)。它读取一个包含很多行(10000行)的文本文件。这些是制表符分隔值,然后我将其解析为Vector对象的Vector。然而,它似乎适用于某些文件(较小),但我的一个文件给我以下错误(该文件有10000行,大小为90MB)。我猜这是一个内存相关的问题?你能帮帮我吗?错误terminatecalledafterthrowinganinstanceof'std::bad_alloc'what():std::bad_allocAbort代码voidAppManager::go(stringcustomerFile){vector>vals=fileReader

c++ - Clang 提示 : "pointer is initialized by a temporary array"

我有一个不同长度的(指向)数组的数组,我了解到我可以使用复合文字来定义它:constuint8_t*constminutes[]={(constuint8_t[]){END},(constuint8_t[]){1,2,3,4,5END},(constuint8_t[]){8,9,END},(constuint8_t[]){10,11,12,END},...};gcc很好地接受了这一点,但clang说:指针由一个临时数组初始化,它将在完整表达式结束时被销毁。这是什么意思?代码似乎可以正常工作,但话又说回来,许多事情似乎在指向不再分配的内存时可以正常工作。这是我需要担心的事情吗?(最终我真

c++ - 为什么我得到 "cannot allocate an array of constant size 0"?

这个问题在这里已经有了答案:WhathappensifIdefinea0-sizearrayinC/C++?(8个答案)关闭8年前。我正在为学校做一个扫雷程序,但我的代码中一直出现这个错误cannotallocateanarrayofconstantsize0我不知道为什么会这样;我没有分配大小——我将它设置为0。另一个问题是,我如何通过char读取我的输入char,这样我就可以将它保存在我的数组?正如您在下面看到的,我正在使用输入和输出。我评论了我的输入和输出,这样你们就可以看到我在这个程序中使用了什么。我想通过char读取char,这样我就可以将所有map保存在数组中。我正在使用M