草庐IT

free-codecs

全部标签

c++ - 如果通过委托(delegate)给 `free` 的重载 `new[]` 分配内存,那么 `malloc` 内存是否安全?

我的问题与Isitsafeto`free()`memoryallocatedby`new`?不重复.我正在为POD编写一个玩具垃圾收集器,我在其中定义了我自己的自定义operatornew/new[]和operatordelete/delete[].代码如下:#include#includestd::mapmemory;//globallyallocatedmemorymapstructcollect_t{}collect;//tagforplacementnewvoid*operatornew(std::size_tsize,constcollect_t&){void*addr=ma

c++ - 什么是 glibc free/malloc/realloc invalid next size/invalid pointer error 以及如何修复它?

您很可能会看到此问题,因为您的问题已作为此问题的拷贝关闭。有关中等完整的相关问题列表,请参阅MetaStackOverflow上的Alonglistofpossibleduplicates— Cmemoryallocationandoverrunningbounds。示例问题来自freechar*:invalidnextsize(fast)由noobie在2014-04-11询问。我在连接过程后释放char*,但收到此错误:free():invalidnextsize(fast):0x0000000001b86170这是我的代码:voidconcat(stringList*list){

c - 释放分配的内存 : realloc() vs. free()

所以我用malloc()分配了一block内存,后来用realloc()进行了更改。在我的代码中的某个时刻,我想清空它,我的意思是本质上给它的内存为0。这可以直观地使用realloc(pointer,0)完成。我在这里读到这是实现定义的,不应使用。我应该改用free(),然后再做一个malloc()? 最佳答案 这取决于你的意思:如果你想清空已使用的内存,但仍然可以访问该内存,那么你使用memset(pointer,0,mem_size);,将所述内存重新初始化为零。如果您不再需要该内存,则只需调用free(pointer);,这将

ios - Xcode - 我的应用程序崩溃,错误是 "Invalid pointer dequeued from free list *** set a breakpoint in malloc_error_break to debug"

我的应用在模拟器上运行完美。但是当我在设备上运行它时,应用程序崩溃并显示错误:"malloc:*errorforobject0x17415d0c0:Invalidpointerdequeuedfromfreelist*setabreakpointinmalloc_error_breaktodebug";我在malloc_error_break中搜索并设置了一个断点进行调试,但还是找不到问题所在。我试图改变项目的方案,启用僵尸对象,但找不到答案。我也尝试使用乐器,但我不擅长。 最佳答案 我已经在iOS8.3上使用Xcode8修复了这个

c - malloc() 和 free() 在哪里存储分配的大小和地址?

malloc()和free()在哪里存储分配的地址及其大小(LinuxGCC)?我读过一些实现将它们存储在实际分配的内存之前的某个位置,但我无法在我的测试中确认这一点。背景,也许有人对此有另一个提示:我正在尝试分析一个进程的堆内存,以确定另一个进程中字符串的当前值。访问进程堆内存并浏览它是没有问题的。但是,由于字符串的值发生变化,并且进程每次都分配新的内存部分,因此字符串的地址发生了变化。因为字符串具有固定格式,仍然很容易找到,但经过一些更改后,字符串的旧版本仍在堆内存中(可能已释放,但仍未重用/覆盖),因此我无法判断哪个字符串是当前字符串。所以,为了仍然找到当前字符串,我想通过将其地

c - free 和 malloc 在 C 中是如何工作的?

我试图弄清楚如果我尝试“从中间”释放指针会发生什么比如看下面的代码:char*ptr=(char*)malloc(10*sizeof(char));for(chari=0;i我遇到了一个带有未处理异常错误消息的崩溃。我想了解free为什么以及如何工作,这样我不仅知道如何使用它,还能够理解奇怪的错误和异常,并更好地调试我的代码ץ非常感谢 最佳答案 当你malloc一个block时,它实际上分配的内存比你要求的多一点。这个额外的内存用于存储信息,例如分配block的大小,以及到block链中下一个空闲/使用block的链接,有时还有一些

c++ - 为什么 new()/delete() 比 malloc()/free() 慢?

为什么new()/delete()比malloc()/free()慢?编辑:感谢到目前为止的回答。请指出标准C++实现new()和delete()的规范,谢谢! 最佳答案 看这段C代码:structdata*pd=malloc(sizeof(structdata));init_data(pd);C++中的new操作符本质上是在做上面这段代码所做的事情。这就是它比malloc()慢的原因。delete也是如此。它的作用与此相同:deinit_data(pd);free(pd);如果构造函数和析构函数为空(如内置函数),new和dele

c++ - 为什么 is_lock_free 是成员函数?

is_lock_free需要实例(它是成员函数)的原因是什么?为什么不是该类型的元函数,或者静态constexpr成员函数?我正在寻找一个实际的例子来说明为什么它是必要的。 最佳答案 标准允许类型有时无锁。section29.4Lock-freepropertyTheATOMIC_..._LOCK_FREEmacrosindicatethelock-freepropertyofthecorrespondingatomictypes,withthesignedandunsignedvariantsgroupedtogether.The

c++ - Python ctypes : how to free memory? 获取无效指针错误

我想从带有ctypes的C/C++库中获取一些字符串到python中。我的代码如下所示:lib中的代码:constchar*get(structsomething*x){[...]//bufisastringstreamreturnstrdup(buf.str().c_str());}voidfreeme(char*ptr){free(ptr);}Python代码:fillprototype(lib.get,c_char_p,POINTER(some_model)])fillprototype(lib.freeme,None,[c_char_p])//whatiwanttodohere

c++ - 为什么 free(p) 不将 p 设置为 NULL?

这不是free()的标准行为的任何原因?多个指针指向同一个对象:#include#includevoidsafefree(void*&p){free(p);p=NULL;}intmain(){int*p=(int*)malloc(sizeof(int));*p=1234;int*&p2=p;printf("p=%pp2=%p\n",p,p2);safefree((void*&)p2);printf("p=%pp2=%p\n",p,p2);safefree((void*&)p);//safereturn0;}来自malloc的赋值要求从void*转换反之亦然:safefree()要求强制