有一个表应该按照确定的功能增长。每次表格填满时,都会调用函数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;
答案 0 :(得分:1)
在现代C库中,malloc通常只是从内核分配的更大块中分配内存。它没有去内核每次请求更多的内存,这将是低效的。
因此CPU和操作系统内核可能不知道出现任何问题,但这是带有未定义行为的无效代码,所以不要这样做。特别是,下一次调用malloc可以重新分配你已经用于其他东西的内存。