zl程序教程

您现在的位置是:首页 >  其他

当前栏目

动态内存分配的常见错误

2023-02-25 18:22:21 时间

前言

本文介绍动态内存分配函数使用时常见的错误~


1,对NULL指针的解引用

下面展示错误代码

int main()
{
	int* p = (int*)malloc(INT_MAX);
	*p = 1;
	printf("%d", *p);
	return 0;
}

错误原因:对NULL指针解引用。

改进方法:分配完空间以后一定要检查是否为空,像这样:

int main()
{
	int* p = (int*)malloc(INT_MAX);
	if (p == NULL) 
	{
		perror("worning::431:");
		return 0;
	}
	*p = 1;
	printf("%d", *p);
	return 0;
}

运行效果图


2,对动态空间越界访问

下面展示错误代码

int main()
{
	int* p = (int*)malloc(10);
	if (p == NULL)
	{
		perror("worning");
		return 0;
	}
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		p[i] = i;
	}
	return 0;
}

错误原因:误认为malloc的参数是以int为单位。

改进方法:无论是malloc还是realloc一律写成n*t的形式,n是个数,t是每个元素的大小,像这样:

int main()
{
	int* p = (int*)malloc(10*sizeof(int));
	if (p == NULL)
	{
		perror("worning");
		return 0;
	}
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		p[i] = i;
	}
	return 0;
}

3,对非动态空间释放

下面展示错误代码

int main()
{
	int a = 1;
	int* p = &a;
	free(p);
	p=NULL;
	return 0;
}

错误原因:对非动态分配的空间进行释放。

改进方法:用完动态内存分配函数马上free,不用动态内存就不要free。


4,释放一部分空间

下面展示错误代码

int main()
{
	int* p = (int*)malloc(10 * sizeof(int));
	p++;
	free(p);
	p=NULL;
	return 0;
}

错误原因:p++后已经不再指向首元素地址,有部分动态空间没被释放,多出来的非动态空间被释放。

改进方法:不对动态开辟的维护变量进行自增自减操作。


5,重复释放空间

下面展示错误代码

int main()
{
	int* p = (int*)malloc(10 * 4);
	free(p);
	free(p);
	return 0;
}

错误原因:对同一块空间多次释放。

改进方法:释放完后立马将维护指针赋为NULL,因为free接收空指针后不做任何操作,像这样:

int main()
{
	int* p = (int*)malloc(10 * 4);
	free(p);
	p=NULL;
	free(p);
	return 0;
}

6,忘记释放空间

下面展示错误代码

void test()
{
	int *p = (int *)malloc(100);
	if(NULL != p)
	{
		*p = 20;
	}
}
int main()
{
	test();
	return 0;
}

错误原因:用完空间后未能及时释放,导致p销毁,空间泄露。

改进方法:用完空间以后及时释放,像这样:

void test()
{
	int *p = (int *)malloc(100);
	if(NULL != p)
	{
		*p = 20;
	}
	free(p);
	p=NULL;
}
int main()
{
	test();
	return 0;
}

感谢您的阅读与耐心~