jjzjj

RedisModule_Alloc

全部标签

c++ - 尽管未定义 <new> header ,但 New 会抛出 bad_alloc?

new是怎么回事?程序中的表达式可以抛出bad_alloc尽管没有#include还是出错(因为这个错误isdefinedintheheader)?来自3.7.4。N3337的:Thelibraryprovidesdefaultdefinitionsfortheglobalallocationanddeallocationfunctions.Someglobalallocationanddeallocationfunctionsarereplaceable(18.6.1).AC++programshallprovideatmostonedefinitionofareplaceablea

c++ - 在抛出 'std::bad_alloc' what(): std::bad_alloc 的实例后终止调用

我的程序中出现了bad_alloc异常。这些是限制条件:1每个字符串的长度最多为100000,并且只包含小写字符。由于这些限制,我无法弄清楚为什么我的程序得到bad_alloc。#include#include#include#includeclassSuffixArray{std::vectorsuffixes;size_tN;public:SuffixArray(std::string&s){N=s.length();suffixes.resize(N);for(size_ti=0;i>T;std::vectorresults;for(inti=0;i>str;SuffixArra

c++ - boost pool_alloc

为什么boost::fast_pool_allocator建立在单例池之上,而不是每个分配器实例一个单独的池?或者换句话说,为什么只提供那个,而不是每个分配器都有一个池的选项?那样做会不会是个坏主意?我有一个类在内部使用大约10种不同的boost::unordered_map类型。如果我使用了std::allocator,那么在它调用delete时所有内存都会返回给系统,而现在我必须在某些时候对许多不同的分配器类型调用release_memory。我自己推出使用池而不是singleton_pool的分配器是否愚蠢?谢谢 最佳答案 分

c++ - 自定义异常层次结构。来自 std::exception 和 std::bad_alloc 的可怕钻石

我在自己的异常层次结构中遇到继承问题。Exception类具有很好的功能(回溯、日志记录等),因此它是我处理任何异常的基类。正如我在许多网页中看到的那样,它继承自std::exception。此外,我正在使用一个单元测试框架来报告任何std::exception被意外抛出。但归根结底,这只是为了方便。然后,我有一个新的OutOfMemoryException类,它将由自定义new_handler抛出。该类继承自Exception,但也继承自std::bad_alloc以兼容现有代码。我猜这更重要,因为new将不再抛出std::bad_alloc。这里的问题很明显:因为std::bad_

c++ - 让 Howard Hinnant 的 short_alloc(C++11 版本)在 Visual C++ 2015 中编译

我希望能够将自定义分配器与std::vector一起使用,以便将小数据缓冲区(例如,小于1024字节)存储在堆栈上,并且只有较长的vector存储在堆上。作为一个有Fortran背景的人,每次我必须进行堆内存分配以在五行子程序的持续时间内存储六个元素时,这让我感到body疼痛!HowardHinnant发表了他的short_alloc分配器完全符合我的要求,如果我用gcc编译它,它会很好用。但是,在VisualC++中我无法编译它。在VisualC++2013中,部分问题是不受支持的C++11关键字太多,但即使我已将所有这些都#DEFINE掉,我仍然遇到了问题。今天尝试用VisualC

c++ - 避免 std::bad_alloc。 new 应该返回一个 NULL 指针

我将一个中型应用程序从C移植到C++。它不会在任何地方处理异常,这一点不应该改变。我(错误!)对C++的理解是(直到我昨天艰难地学习它)(默认)new运算符在出现分配问题时返回NULL指针。然而,直到1993年(左右)才出现这种情况。现在,它抛出一个std::bad_alloc异常。是否可以在不重写所有内容以在每次调用时使用std::nothrow的情况下返回到旧行为? 最佳答案 你可以重载operatornew:#includevoid*operatornew(size_tpAmount)//throw(std::bad_allo

ios - stub [[SomeClazz alloc] init] 不工作但接受的答案说它应该工作

我测试的功能很简单:@implementationMyHandler...-(void)processData{DataService*service=[[DataServicealloc]init];NSDictionary*data=[servicegetData];[selfhandleData:data];}@end我使用OCMock3对其进行单元测试。我需要stub[[DataServicealloc]init]以返回一个模拟实例,我尝试了answerfromthisquestion(这是一个公认的答案)stub[[SomeClazzalloc]init]://Stub'al

iphone - alloc initWithObjects 与 arrayWithObject

我不明白为什么要写这些代码icons=[[NSArrayalloc]initWithObjects:@"appointment",@"work",@"anniversary",@"me",nil];应用程序崩溃了。但后来我用这些代码代替了icons=[NSArrayalloc]arrayWithObjects:@"appointment",@"work",@"anniversary",@"me",nil];而且应用程序没有崩溃。但是这些方法之间的影响是一样的!我不知道为什么?你能帮帮我吗? 最佳答案 initWithObjects方

Erlang模块erts_alloc翻译

C库      erts_alloc库摘要    Erlang运行时系统内部内存分配器库。描述      erts_alloc是一个Erlang运行时系统内部内存分配器库。erts_alloc为Erlang运行时系统提供了许多内存分配器。分配器    存在以下分配器:temp_alloc用于临时分配的分配器。eheap_alloc用于Erlang堆数据(例如Erlang进程堆)的分配器。binary_alloc用于Erlang二进制数据的分配器。ets_alloc用于ets数据的分配器。driver_alloc用于驱动程序数据的分配器。literal_alloc用于Erlang代码中常数项的分

ios - Objective-C NSMutableArray alloc init 在已经声明的对象上

我的任务是“清理”其他人的Objective-C代码。我承认,这当然不是我最喜欢的语言。我在这个用户的代码中发现的一个对我来说似乎多余的方法是:if(favoriteItemsArray||[favoriteItemsArraycount]>0){[favoriteItemsArrayremoveAllObjects];favoriteItemsArray=nil;}if(favoriteOrderArray||[favoriteOrderArraycount]>0){[favoriteOrderArrayremoveAllObjects];favoriteOrderArray=nil