C结构未初始化的外部构造函数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C结构未初始化的外部构造函数相关的知识,希望对你有一定的参考价值。

我有这个'JobSequence'结构,我想在我的main函数中实例化。为此,我创建了一个new_JobSequence()函数,它分配内存并为结构的所有字段赋予适当的值。在这个函数中,根据我的调试器,一切都正确完成。但是一旦我回到我的主要功能,int cost被设置为任意值,baseInstance = 0x0list = 0x1jobSequence之前和之后的new_JobSequence()地址不变,与函数内部使用的地址相同。以下是结构的声明,函数的代码和main:

typedef struct JobSequence{
    Instance* baseInstance;
    List* sequence;
    int cost;
}JobSequence;

void new_JobSequence(Instance* baseInstance, JobSequence* jobSequence){
    jobSequence = malloc(sizeof(JobSequence));
    jobSequence->baseInstance = baseInstance;
    jobSequence->cost = 0;
    list_new(&jobSequence->sequence);
}

int main() {
    int** P = baseInstance();
    Instance instance;
    makeInstanceFromBin(P,10,10,4,&instance);
    printInstance(&instance);
    JobSequence jobSequence;
    setbuf(stdout, 0);
    printf("address : %p
",&jobSequence);
    new_JobSequence(&instance,&jobSequence);
    setbuf(stdout, 0);
    printf("address : %p
",&jobSequence);

    Do other stuff (crashes because I try to access the elements of jobSequence which have 0x1 and 0x0 addresses).
}

所以我真的尝试了很多东西,但我真的无法弄清楚这里发生了什么......

谢谢您的帮助。

答案

当你写作

JobSequence jobSequence;

您要求编译器在堆栈上创建JobSequence类型的变量。

所以你不必为此自己保留记忆。

您在调试器中遇到的问题是jobSequence函数中的main未被new_JobSequence函数修改。

您可以通过一些调试跟踪来查看它:

void new_JobSequence(Instance* baseInstance, JobSequence* jobSequence){
    printf("start of %s: js is %p
", __FUNCTION__, jobSequence);
    jobSequence = malloc(sizeof(JobSequence));

    printf("after malloc, js is %p
", jobSequence);
    jobSequence->baseInstance = baseInstance;
    jobSequence->cost = 0;
    list_new(&jobSequence->sequence);       
}

因此,要使您的函数适用于在main中创建的变量,您必须编写如下内容:

void new_JobSequence(Instance* baseInstance, JobSequence* jobSequence)
{
    jobSequence->baseInstance = baseInstance;
    jobSequence->cost = 0;
    list_new(&(jobSequence->sequence));
}

...
int main(void)
{
    /* ... */
    JobSequence jobSequence;
    new_JobSequence(..., &jobSequence);
}

如果要在堆上为结构分配内存,则必须遵循以下方法:

JobSequence *new_JobSequence(Instance* baseInstance){
    JobSequence *js= malloc(sizeof *js);
    js->baseInstance = baseInstance;
    js->cost = 0;
    list_new(&(js->sequence));

    return js;
}

...
int main(void)
{
    /* ... */
    JobSequence *jobSequence = new_JobSequence(...);                
}
另一答案

您已在主函数中分配了实例。所以你在new_JobSequence()中真正做的只是在堆中分配一些内存,初始化它并且在退出该函数之前永远不会返回任何内容。如果你想保持这个操作流程,你需要将一个双指针传递给你的函数(并在你的主函数中正确分配一个指针,即JobSequence *pJobSequence = NULL)。

以上是关于C结构未初始化的外部构造函数的主要内容,如果未能解决你的问题,请参考以下文章

C++/Win32 构造函数未使用从对话框获得的字符串初始化变量

c语言如何对结构体某一成员初始化

用于创建/维护外部结构的 C++ 构造函数链接

C ++中的结构构造函数?

使用c中的指针初始化结构的构造函数值[重复]

如何使我的构造函数和函数工作,以便我的main()能够显示字符串和int数据?