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

相关推荐
XiYang-DING几秒前
【Java】 Java 集合框架
java·开发语言
charlie1145141911 分钟前
嵌入式C++教程实战之Linux下的单片机编程(9):HAL时钟使能 —— 不开时钟,外设就是一坨睡死的硅
linux·开发语言·c++·单片机·嵌入式硬件·c
以太浮标3 分钟前
华为eNSP模拟器综合实验之- DHCP、DNS、HTTP和FTP服务器配置案例Client-Server
linux·服务器·windows·http·华为·信息与通信
liu****4 分钟前
第十五届蓝桥杯大赛软件赛国赛C/C++大学B组
c++·算法·蓝桥杯·acm
zhooyu5 分钟前
利用叉乘判断OpenGL中的左右关系
c++·3d·opengl
diving deep6 分钟前
从零构建大模型--实操--搭建python环境
开发语言·python
We་ct6 分钟前
LeetCode 172. 阶乘后的零:从暴力到最优,拆解解题核心
开发语言·前端·javascript·算法·leetcode·typescript
沉淀粉条形变量18 分钟前
rust 单例模式
开发语言·单例模式·rust
光电笑映22 分钟前
C++11 新特性全解:语法糖、容器进化与可调用对象包装
开发语言·c++
qq_白羊座24 分钟前
Langchain、Cursor、python的关系
开发语言·python·langchain