您的位置:首页 > 编程语言 > C语言/C++

C语言指针的易错点

2016-07-13 00:07 453 查看
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);
}


  

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: