用malloc,struct和char *堆腐败*

时间:2012-07-26 10:02:26

标签: c memory malloc heap heap-corruption

我的C程序中似乎有内存损坏。我使用_ASSERTE( _CrtCheckMemory( ) );来查找问题陈述,并在它前面的scep_conf->engine_str = NULL;行中断。所以,如果我理解正确的话,之前的malloc会破坏某些东西,对吗?

因此,这是导致问题的代码的一部分:

scep_conf = (SCEP_CONF *) malloc(sizeof(scep_conf));
scep_conf->engine = (struct scep_engine_conf_st *) malloc(sizeof(struct scep_engine_conf_st));
scep_conf->engine_str = NULL;

标题中的定义:

typedef struct {
    struct scep_engine_conf_st *engine;
    char *engine_str;
} SCEP_CONF;

struct scep_engine_conf_st{
    char *engine_id;
    char *new_key_location;
    int storelocation; 
    char *dynamic_path;
    char *module_path; 
    int engine_usage;
};

SCEP_CONF *scep_conf;

基本上我不明白为什么它会破坏我的记忆。我是C的新手,因此我可能会看到一些我没有看到的东西。

非常感谢任何帮助,谢谢。

1 个答案:

答案 0 :(得分:6)

这是不正确的:

scep_conf = (SCEP_CONF *) malloc(sizeof(scep_conf)); 

因为它只为SCEP_CONF*分配足够的内存,而不是SCEP_CONF。它应该是:

scep_conf = malloc(sizeof(*scep_conf)); /* cast unnecessary. */

值得一读Do I cast the result of malloc?