我有一个很奇怪的问题,尝试在分配的内存上免费调用会导致我的程序崩溃。
以下是相关代码:
int i, count;
char *specifier;
char aisle[1];
count = 0;
/*Find name of the new item and assign to the name field of new_node...*/
for (i = 0; input[i] != ','; i++){
count++;
}
specifier = (char*)malloc((count+1)*sizeof(char));
if (specifier == NULL){
printf("Out of memory. Shutting down.\n");
exit(EXIT_FAILURE);
}
for (i = 0; input[i] != ','; i++){
specifier[i] = input[i];
}
specifier[count+1] = '\0';
new_node->name = specifier;
printf("%s\n", new_node->name);
free(specifier); /*PROGRAM CRASHES HERE*/
printf("boom\n");
specifier = NULL;
/*Function continues here*/
这是我用于new_node的结构:
/*Outline for the stock levels system...*/
typedef struct item item_t;
struct item{
char *name;
char *aisle;
item_t *left;
item_t *right;
};
当我运行程序时,第一个printf可以正确打印,但是第二个则不能。有什么想法吗?
最佳答案
您为count + 1
元素分配空间...
specifier = (char*) malloc ( (count+1) * sizeof(char));
然后经过数组( undefined 的行为):
specifier[count + 1] = '\0';
关于c - 调用free()导致我的程序崩溃,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/30191242/