C语言中malloc函数的6种常见错误
今天就讲述一下生活中malloc的6种常见错误,这些错误都是值得注意的哟!废话不多说,直接上代码。(本人笔记资料来自学习网站,仅用于学习,如有侵权,请联系删除)
- 动态开辟内存失败后,对NULL指针的解引用操作
对于动态开辟内存可能会存在开辟失败的情况,如下:
int* p = malloc(10 * sizeof(int));
//malloc开辟空间失败 将会对NULL指针解引用
*p = 10;
free(p);
所以在每次开辟完空间后需要进行判断,如下:
//需要进行对开辟空间进行判断
int* p = malloc(40);
if (p == NULL)
return 0;
*p = 10;
free(p);
- 对动态开辟内存的越界访问
对于自己开辟的空间大小,一定要知道,要不然便会出现越界访问(和数组越界类似)
int* p = (int*)malloc(20 * sizeof(int));
if (p == NULL)
return 0;
int i = 0;
//出现越界情况
for ( i = 0; i <= 20; i++)
{
*(p + i) = i;
}
free(p);
- 对非动态开辟内存进行释放
非动态开辟内存空间不能进行free函数释放,如下是示例代码:
int c = 20;
int* p = &c;
free(p);
p = NULL;
- 指针移动导致free释放开辟内存的一部分
指针偏移会导致内存释放的不成功,导致出错
int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
return 0;
int i = 0;
for (i = 0; i < 10; i++)
{
//此时指针偏移
*p++ = i;
}
free(p);
p = NULL;
- 同块开辟内存多次释放
同块内存进行多次释放会导致程序出错,但是当释放第一次时,把指针变为NULL便能解决此问题
int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
return 0;
free(p);
//此处把p变为NULL 便能避免错误
p = NULL;
free(p);
- 动态开辟内存未释放导致的内存泄漏
动态开辟如若不及时释放便会造成内存泄漏,所以要遵守谁开辟谁释放原则
void demo()
{
int* p = (int*)malloc(10*sizeof(int));
if(p ==NULL)
return 0;
}
int main()
{
demo();
while(true);
}
目前正在从0到1哦,笔记大部分都是来自于在网站上学习时的总结。如有侵权,请联系删除。
未完待续。。。