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.栈区局部变量的地址不要往外传。如:
7.同一块内存区域被多次释放;如
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); }
相关文章推荐
- 详谈C++虚函数表那回事(一般继承关系)
- 详谈C++虚函数表那回事(一般继承关系)
- c++小工具,运用于游戏中的多叉树
- 李洪强漫谈iOS开发[C语言-009] - C语言关键字
- c/c++的笔记(看到想记录的就添加)
- 设计模式之c++实现(一)
- 三个简单工厂实例 - C++实现
- C++及C语言字符串反转
- C++内存分布之虚函数和虚表
- C语言数据类型(二)——数据类型重要知识点
- C语言
- C语言数据类型(一)——基本知识点
- C语言学习-分支结构
- 1054. The Dominant Color (20)
- 迭代器模式-c++实现
- Ubuntu12.04升级C++11标准
- 【C++笔记】函数中参数传递
- C++ 类模板四(typename关键字)
- 306. Additive Number 给定字符串分割进行类似斐波那契数列
- 改善C++程序的建议:语法篇1<从C继承而来的特性>