C语言指针的易错点

1.内存泄漏:申请的堆内存没有释放。

2.内存污染:前面非法操作使用内存(没有报错),后面写着写着就出错。如下代码:

当结构体中只有划线部分代码时,在编译器中编写不会报错,但此时已经造成非法操作内存,下面再给结构体添加一些变量,此时就会报错,不让再定义变量(这种错误特别不好调试)需要注意。

3.对空字符串和非法字符串的判断:

图中画蓝线的部分:应该判断的是指针变量的值,而不是指针指向的内存

4.指针越界:如:str[3] = "abc";

5.指针的叠加会不断改变指针的指向。

如:char *p ="sdfg";   p++;  printf("%s\n",p);打印结果为:"dfg";。指针的只想被改变,如果再叠加4次,就打印不出内容了,因为指针此时已经指向了结束符。

6.栈区局部变量的地址不要往外传。如:

char *get_str()
{
	char str[] = "abcdedsgads"; //栈区,
	printf("[get_str]str = %s\n", str);
	return str;
}

7.同一块内存区域被多次释放;如

har *p = NULL;

p = (char *)malloc(50);
strcpy(p, "abcdef");

if (p != NULL)
{
	//free()函数的功能只是告诉系统 p 指向的内存可以回收了
	// 就是说,p 指向的内存使用权交还给系统
	//但是,p的值还是原来的值(野指针),p还是指向原来的内存
	free(p);
}

if (p != NULL)
{
	free(p);
}

  

 

posted on 2016-07-13 00:07  路之遥_其漫漫  阅读(1148)  评论(0编辑  收藏  举报

导航