一.动态内存分配:
步骤:
1 用malloc类的函数分配内存
2 用这些内存支持应用程序
3 用free函数释放内存
容易出现的问题:
1 内存泄漏
malloc分配的内存生存周期是直到释放。若是一直不释放,则会让程序用光内存然后非正常终止
如:
char *p;
while(1)
{
p=(char *)malloc(10000000);
printf("allocating\n");
}
p指向堆上的内存。但无限循环会使内存耗尽。
2 丢失地址
当p被赋值为一个新地址后,丢失原来malloc函数(或其他函数)申请的内存的地址。
如:
char *name=(char *)malloc(strlen("susna")+1);
strcpy(name,"susan");
while(*name!=0)
{
printf("%c",*name);
name++;//该句使得name指针最终指向字符串结尾的NUL字符,使malloc申请的地址丢失。
}
free(p);会发现出现断错误。因为内存丢失
纠正方式是,用一个新指针:
char *p=name;
while(*p!=0)
{
printf("%c",*p);
p++;
}
free(p);
动态内存分配函数:
malloc
realloc 在之前分配内存块的基础上,将内存重新分配为更大或者更小部分
calloc 分配内存并清零
free
特例:realloc(NULL,size)相当于malloc(size)
realloc(ptr,0) ptr不为NULL,相当于free(ptr)
步骤:
1 用malloc类的函数分配内存
2 用这些内存支持应用程序
3 用free函数释放内存
容易出现的问题:
1 内存泄漏
malloc分配的内存生存周期是直到释放。若是一直不释放,则会让程序用光内存然后非正常终止
如:
char *p;
while(1)
{
p=(char *)malloc(10000000);
printf("allocating\n");
}
p指向堆上的内存。但无限循环会使内存耗尽。
2 丢失地址
当p被赋值为一个新地址后,丢失原来malloc函数(或其他函数)申请的内存的地址。
如:
char *name=(char *)malloc(strlen("susna")+1);
strcpy(name,"susan");
while(*name!=0)
{
printf("%c",*name);
name++;//该句使得name指针最终指向字符串结尾的NUL字符,使malloc申请的地址丢失。
}
free(p);会发现出现断错误。因为内存丢失
纠正方式是,用一个新指针:
char *p=name;
while(*p!=0)
{
printf("%c",*p);
p++;
}
free(p);
动态内存分配函数:
malloc
realloc 在之前分配内存块的基础上,将内存重新分配为更大或者更小部分
calloc 分配内存并清零
free
特例:realloc(NULL,size)相当于malloc(size)
realloc(ptr,0) ptr不为NULL,相当于free(ptr)