c malloc 导致崩溃

标签 c struct crash malloc

为什么上面的 3 个 malloc 会崩溃?有时它们有效,但仅适用于 (globale->dim_schema) > 10 或 (globale->dim_schema) >100

struct GLOBALE {

    int dim_schema;
    char *schema;
    int *celle_usate;
    char *punteggi;
    char *percorso_aiuto;
    struct LISTA_SOLUZIONI *soluzioni; 
};

typedef struct GLOBALE *struct_globale;

void modalita_interattiva() {

    int i;
    char lettera;

    char bonus;
    char *parola;
    struct_globale globale;
    globale = malloc(sizeof(struct_globale));

    if(globale == NULL) {

        printf("Impossibile creare struct globale\n");
        exit(EXIT_FAILURE);

    globale->soluzioni = NULL;

    do{
        printf("Quanto grande e' lo schema di ruzzle che vuoi usare? (>0)\n");
        scanf("%d", &(globale->dim_schema));
        printf("Dimensione: %d \n", globale->dim_schema);
    }while(globale->dim_schema<=0);

    globale->celle_usate = malloc(globale->dim_schema * globale->dim_schema * sizeof(int)); <----CRASH
    printf("celle usate\n");
    globale->punteggi = malloc((globale->dim_schema) * (globale->dim_schema) * sizeof(char)); <----CRASH
    printf("punteggi\n");
    globale->schema = malloc(globale->dim_schema * globale->dim_schema * sizeof(char));<----CRASH
    printf("schema\n"); 
...etc etc

最佳答案

这是一个很好的例子,说明了为什么在 typedef 中隐藏指针不是一个好主意:

globale = malloc(sizeof(struct_globale));

struct_globalestruct GLOBALE * 的类型定义。因此,上述分配仅为指向 struct GLOBALE 的指针分配足够的空间(通常为 4 或 8 个字节,具体取决于机器/编译器)。由于结构体大于此值,因此您正在写入超出分配大小的内存偏移量的成员。这会导致未定义的行为。

您需要为结构的大小分配空间:

globale = malloc(sizeof(struct GLOBALE));

或者:

globale = malloc(sizeof(*globale));

关于c malloc 导致崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36896223/

相关文章:

ctrl-d 没有停止 while(getchar()!=EOF) 循环

c++ - 在 C++ 中调用另一个函数时,编译器在参数中查找已删除的构造函数

c - 链接列表、干扰控制台

android - Android 中的 WebRtc 崩溃

c - Tilde C 无符号整数与有符号整数

c - 如何使用宏更改某些文本中的数字

c++ - C 明显比 C++ 快吗

c - 指针如何与 C 中的双向链表一起工作?

c# - dSYM 文件夹和 mSYM 文件夹有什么区别?

ios - 如何找出导致我的 iOS 应用程序崩溃的原因(EXC_BREAKPOINT)?