1

首先,让我首先说我知道这个问题已经在某个时候得到了回答。它必须是,但我根本不知道要找到答案的关键字。

我正在编写一个程序,在我的程序内部,我必须在各处创建多个动态大小的数组,然后将它们存储到一个大结构中。因此,如果我必须创建相同类型的动态分配数组,我会在一个函数中创建它(即声明它、malloc 并返回它)到我的结构字段。然而,现在我已经走上了这条路,我认为我犯了一个重大缺陷。我相信我所做的会被函数的作用域破坏,这意味着一旦函数完成,原始指针就会被杀死,因此我的结构是指向不再是“我的”地址的指针。下面是对该函数的示例调用,希望它在没有注释的情况下有意义。

//Call from main()
current_event->mens_names = create_names_matrix(number_of_couples, 20);

//my "create_names_matrix" function:
char ** create_names_matrix(int num_of_names, int length_of_names){
int i;
char **return_matrix;

return_matrix = malloc(num_of_names * sizeof(char*));
if(return_matrix == NULL){
    panic("return_matrix"); //Panic is a function that checks if malloc failed
}

for(i = 0; i < num_of_names; i++){
    return_matrix[i] = malloc(length_of_names * sizeof(char));
}

if(return_matrix[i-1] == NULL){
    panic("return_matrix"); //Panic is a function that checks if malloc failed
}
return return_matrix;

}

解决方案是继续声明并在主中动态创建每个字段数组,然后将其作为参数传递给我的每个“create_xxx_matrix”函数,以避免在函数范围完成后它们被杀死?

我知道这是一个菜鸟问题,但自从我使用指针和 c 以来已经有一段时间了。

谢谢!

4

2 回答 2

2

动态分配的指针是在堆中分配的,不会被函数范围杀死。根据作用域,分配在堆栈中的变量一旦离开函数就会被销毁。

于 2013-02-03T04:08:42.140 回答
0

这将正常工作。你真正担心的不是指针本身,而是它指向的内存。指针实际上只是一个指示内存位置的数字(如 0x0043AF)。由于您使用malloc()了您的内存在堆上,除非您专门调用free(ptr)这将释放所有指向的内存,否则它永远不会被释放。

于 2013-02-03T07:30:31.223 回答