gpt4 book ai didi

c - free() 在 c 代码中收集垃圾值,即使在释放后将指针设置为 NULL,代码也不起作用

转载 作者:太空宇宙 更新时间:2023-11-04 04:48:05 26 4
gpt4 key购买 nike

当我尝试调用 free() 函数来释放内存时,它无法正常工作。这是我的代码:

unsigned char *indata;
unsigned char *outdata;

int file_func(const char *filename) {
//some other variables

for(i=0;i < no_of_files;i++) {
indata = malloc(sizeof(unsigned char));
outdata = malloc(sizeof(unsigned char));

//counts the number of characters from filename
numCharacters = readfile(filename, indata);

/* perform some operation on indata and get outdata(size is same as indata)*/

writefile(filename, outdata); //writes outdata to filename

free(indata);
free(outdata);
}
}

上面的代码无法正常工作,因为 free() 在 indata 和 outdata 中存储了一些随机垃圾值(因为它们变成了悬挂指针)。所以我尝试在释放后将指针设置为空,因为我重用了与以下相同的指针:

    free(indata);
indata = NULL;
free(outdata);
outdata = NULL;

即便如此,我的代码也会崩溃:

双重释放或损坏(输出):0x00000000025aa240 *

我怎样才能克服这个问题,或者有没有其他方法可以在循环中使用动态大小的指针。谢谢。

最佳答案

您只需为每个变量分配 1 个字节 (sizeof(unsigned char))。这是一个错误,您想要分配 sizeof(unsigned char) * some_number 其中 some_number 是动态的,或者您可以只在堆栈上分配:

unsigned char indata, outdata; // then use &indata and &outdata where you need a pointer

unsigned char indata[some_number];
unsigned char outdata[some_number];

或者您可以在循环之前 malloc 一次并在循环之后释放一次。

双重释放问题看起来像是您在循环中调用的函数之一正在调用释放。仔细看readfile和writefile。

关于c - free() 在 c 代码中收集垃圾值,即使在释放后将指针设置为 NULL,代码也不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18965133/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com