我们接着C语言动态内存管理(上)没讲完整的继续来深度讲解。、
4. 常⻅的动态内存的错误
4.1 对NULL指针的解引⽤操作
主要的原因还是自己的粗心大意没有对malloc的值进行判断
void test()
{
int *p = (int *)malloc(INT_MAX/4);
*p = 20; //如果p的值是NULL,就会有问题
free(p);
}
其实编译器也会有提示:
这是第一个问题
4.2 对动态开辟空间的越界访问
void test()
{
int i = 0;
int *p = (int *)malloc(10*sizeof(int));
if(NULL == p)
{
exit(EXIT_FAILURE);
}
for(i=0; i<=10; i++)
{
*(p+i) = i; //当i是10的时候越界访问
}
free(p);
}
4.3 对⾮动态开辟内存使⽤free释放
test() 1
{
int a = 10;
int *p = &a;
free(p); //ok?
}
原因很简单
free只能释放我们在栈区开辟的空间(malloc calloc realloc)
其他地方开辟的空间不能被free释放的。
4.4 使⽤free释放⼀块动态开辟内存的⼀部分
void test()
{
int *p = (int *)malloc(100);
p++;
free(p); //p不再指向动态内存的起始位置
}
我们可以观察到程序崩了,所以这样是会出问题的。
4.5 对同⼀块动态内存多次释放
void test()
{
int *p = (int *)malloc(100);
free(p);
free(p); //重复释放
}
那么有什么好的解决办法吗?
我们可以把 p 设为空指针,它什么事都不会干。这样程序是可以进行的。
4.6 动态开辟内存忘记释放(内存泄漏)
void test()
{
int *p = (int *)malloc(100);
if(NULL != p)
{
*p = 20;
}
}
int main()
{
test();
while(1);
}
忘记释放不再使⽤的动态开辟的空间会造成内存泄漏。
切记:动态开辟的空间⼀定要释放,并且正确释放。
大家不要走开,明天我会发布C语言动态内存管理的经典笔试题。还请大家不要错过
谢谢你的观看。