![](https://i-blog.csdnimg.cn/blog_migrate/d9f9e62a839c5cef68dd4d0c72a1daab.jpeg)
引言
我们在工作中,经常会遇到野指针引起的问题。终归到底,还是编码不规范导致的。本文就此话题进行展开讨论。
野指针:
指向不确定地址的指针变量。(即没有初始化)使用野指针易因内存泄露出现段错误。而造成内存泄露的原因有两个:
- 访问了没有权限的内存(平时我们正确使用指针的时候,系统应经将相应的内存分配给用户,但是如果指向没有分配的内存,系统会判定我们没有权限)
- 访问了已经释放了的内存。
因为野指针主要是因为我们
平时编程习惯造成的,因此我们只能避免野指针的出现,而不能杜绝。(请注意用词)我们在编程时,做到以下几点可以有效地避免野指针的出现。
第一,当一个指针没有指向时,我们一般默认指向NULL。(NULL代表内存的0地址,并且NULL是不允许做任何操作的)
第二,使用malloc分配内存。(在堆空间里分配内存)
#difine MAX_SIZE 1024;
char *ptr = (char *) maollc (sizeof (char) * MAX_SIZE);
请认真研究这样的表达式的优点,这个表达式在代码的维护性,扩展性都大大提高了。这方面是我们平时写代码时所应该提高的。
使用malloc也是有讲究的,我们应该依照下面的流程:
- 分配内存。(分配成功,返回内存的首地址;分配不成功,返回NULL)。
- 检查是否分配成功(若失败,则 exit(1) 退出程序)。
- 清空内存中的数据 (malloc分配的空间里可能存在垃圾值,因此我们需要清空,可以用到memset或bzero 函数)。
- 使用内存。
- 释放内存(free,这时ptr又变成野指针)。
- 写成NULL。
我相信只要大家在平时写代码是做到以上几点,是可以很好地避免野指针的出现。
若我的内容对您有所帮助,还请关注我的公众号。不定期分享干活,剖析案例,也可以一起讨论分享。
我的宗旨:
踩完您工作中的所有坑并分享给您,让你的工作无bug,人生尽是坦途
![](https://i-blog.csdnimg.cn/blog_migrate/1d01c802ace3a55796b37235d8179057.jpeg)