十一、做高并发内存池项目过程中遇到的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呢?如果有,你是怎么解决的呢?不妨来评论区留言一下,让更多的小伙伴能够早早避坑吧!!!

相关推荐
枫景Maple3 小时前
C#字典Dictionary的内部实现原理
开发语言·c#
跟我聊天我会闯红灯4 小时前
如何开发一个运行在windows系统服务器上的服务
运维·服务器·windows
刘火锅5 小时前
Bug 记录:SecureRandom.getInstanceStrong()导致验证码获取阻塞
spring boot·spring·spring cloud·bug
上单带刀不带妹6 小时前
Node.js 中的 fs 模块详解:文件系统操作全掌握
开发语言·javascript·node.js·fs模块
牵牛老人6 小时前
Qt中的QWebSocket 和 QWebSocketServer详解:从协议说明到实际应用解析
开发语言·qt·网络协议
chenglin0166 小时前
制造业ERP系统架构设计方案(基于C#生态)
开发语言·系统架构·c#
凌晨7点6 小时前
控制建模matlab练习13:线性状态反馈控制器-②系统的能控性
开发语言·matlab
要记得喝水6 小时前
汇编中常用寄存器介绍
开发语言·汇编·windows·c#·.net
shi57837 小时前
C# 常用的线程同步方式
开发语言·后端·c#
凌晨7点7 小时前
控制建模matlab练习11:伯德图
开发语言·matlab