没有malloc就没有分段错误

时间:2013-12-22 10:46:02

标签: c segmentation-fault malloc

有一个表应该按照确定的功能增长。每次表格填满时,都会调用函数addMemory,使当前table->表格大小加倍。然而,一切似乎都运行正常,只是为了测试程序,我评论了addMemory调用,所以我期待一个分段错误,因为没有向操作系统请求新的内存,但它没有失败,它实际上是在malloc的内存空间旁边写数据没有任何错误。 我想知道为什么会这样?

代码在这里:

 int main(){
    //user* newUser = (user*)malloc(BASE_SIZE*sizeof(user));
    user* newUser = (user*)malloc(sizeof(user));

    userTable* table = (userTable*)malloc(sizeof(userTable));
    newUser->age = 1000;
    table->length = 0;
    table->table= newUser;
    table->length++;

    int i = 0;
    int memlimit = 1000;
    for(i = 1; i < memlimit; i++){
        if(memZone(table->length-1) != memZone(table->length)){
//this is the line that asks for more memory 
            addMemory((void*)table,"userTable");
            printf("mem pos =%i, age = %i\n",table->length,table->table[i-1].age);
        }
        table->table[i].age = (1000 + i);
        table->length++;

    }

    printf("All memory have been successfully allocated \n");
    int anything;
    while(scanf("%i",&anything)){
        reduceMemory((void*)table,"userTable");
        printf("Age = %i \n",table->table[table->length - 1].age);

    }
}

结构定义就是这些:

typedef struct {
    /* Username unique for this user in the system */
    char username[25];

    /* User name */
    char name[100];

    /* Age */
    unsigned int age;

    /* User city */
    char city[128];

} user;

/* Table of users */
typedef struct {
    /* Array of users */
    user* table;
    /* Number of registers in the table */
    int length;
} userTable;

1 个答案:

答案 0 :(得分:1)

在现代C库中,malloc通常只是从内核分配的更大块中分配内存。它没有去内核每次请求更多的内存,这将是低效的。

因此CPU和操作系统内核可能不知道出现任何问题,但这是带有未定义行为的无效代码,所以不要这样做。特别是,下一次调用malloc可以重新分配你已经用于其他东西的内存。