十一、做高并发内存池项目过程中遇到的bug以及调试bug的方法和心得

十一、做高并发内存池项目过程中遇到的bug以及调试bug的方法和心得

第一个bug是内存问题,程序直接崩溃,问题出现在:GetOneSpan函数中的切分span的时候结尾的span1的next没有置空。

第二个bug是还小内存块给span的时候找不到小内存所属的span,原因是NewSpan函数中的一个if分支返回前没有把id和span*的映射关系存好。

修bug前:

修bug后:

第三个bug出现在释放内存的判断条件上,自己定义的变量MAX_BYTES和C++库里面定义的一个宏MAXBYTES混到了一起,本来是用自己定义的这个MAX_BYTES变量作为判断条件的,但是手误写成了C++库中的宏MAXBYTE,导致释放内存的时候出现了很严重的问题,这个bug调试了三天才调试出来,真的很坑。

修改bug前:

修bug后:

我在调上述bug的时候所用的技巧:

1、首先用屏蔽法,先判断是那一段逻辑出现问题,比如先屏蔽内存池释放的逻辑,看看程序是否能正常运行,如果能则说明就是释放的逻辑出了问题,再对释放的逻辑使用屏蔽法排查。

2、在确定了大概是哪一段逻辑出现问题之后可以利用条件断点查看运行到某一个地方的时候的结果是否符合预期。

3、可以查看调试中的调用堆栈查看函数的调用情况。

4、在调试过程中发现疑似死循环的时候可以点击中断程序查看。

以上是一些很实用的调试技巧,但是调试程序最终还是要逐步看,逐步分析结果,一定要细心分析才能调出bug。由于这个项目都是内存分配的问题,出现bug非常不好查,总之一句话,写的时候认真认真再认真,重要的事情说三遍,不然一个bug够你调3天的了。

那这个项目就到此为止了,你做得怎么样呢?做的过程中有没有遇到过什么bug呢?如果有,你是怎么解决的呢?不妨来评论区留言一下,让更多的小伙伴能够早早避坑吧!!!

相关推荐
JavaEdge.10 分钟前
java.io.IOException: Previous writer likely failed to write hdfs报错解决方案
java·开发语言·hdfs
oioihoii22 分钟前
程序员如何系统入门Vibe Coding?
c++
C+++Python26 分钟前
C++类型判断
开发语言·c++
黎雁·泠崖34 分钟前
整数的N进制字符串表示【递归+循环双版满分实现】
c语言·开发语言
张张努力变强39 分钟前
C++类和对象(一):inline函数、nullptr、类的定义深度解析
开发语言·前端·jvm·数据结构·c++·算法
独自破碎E39 分钟前
Java的CMS垃圾回收流程
java·开发语言
oioihoii1 小时前
C++线程编程模型演进:从Pthread到jthread的技术革命
java·开发语言·c++
小美单片机1 小时前
Proteus 报错 Unable to open HEX file ‘..\1、程序\jio\jtd.hex‘. [U1]
c语言·单片机·嵌入式硬件·51单片机·proteus
2501_941322031 小时前
道路检测新突破:Cascade R-CNN在COCO数据集上的实战应用详解
开发语言·r语言·cnn