GDB使用checkpoint复现bug
2024-09-05 17:39:53
今天面试被问到一个问题,如何调试多进程的程序,我回答gdb attach [pid],之后又问如果程序中有些数据读取不对,但这种现象是偶然发生的,这时候要怎么操作,当时就懵了......,通过查找资料找到了答案,现在写篇博文记下来。
checkpoint
有些时候bug的出现是偶然发生的,如果有东西可以保存当前的状态就好了;在GDB中使用checkpoint, GDB可以保存那一刻的程序状态或者说是程序映像(除了进程号和已经输出的内容),并且可以再次返回到那个程序的状态;每个checkpoint都有一个唯一的进程id,这个pid与原始程序的pid不同,因此如果程序需要使用pid的信息时,需要慎重考虑。
通过以下命令使用快照:
checkpoing: 生成当前状态的快照
info checkpoint:显示快照信息
restart checkpoint-id:恢复到某个checkpoint
delete checkpoint checkpoint-id:删除某个checkpoint
对于偶现的问题,可以先定位到触发条件的位置,之后结合日志分析。
最新文章
- PowerDesigner逆向工程导入MYSQL数据库总结
- C# 进制转换 (没有数值的长度限制)
- Android大神博客
- vs 颜色设置
- bzoj 1005 1211 prufer序列总结
- 趋势or过渡,量子点屏幕真的优于OLED?
- C#学习笔记(二)——变量和表达式
- JavaScript:通过id来进行元素的取得
- 基于tcpdump实例讲解TCP/IP协议
- SQL Server 数据类型映射 (ADO.NET)
- QT5.7交叉编译安装到arm(好多系列文章)
- 转载:Java多线程中join方法的理解
- CString与char *互转总结
- poj1159二维树状数组
- 19 子线程刷新UI runOnUiThread
- RequireJS模块化编程详解
- 转://Oracle 单引号转义
- fillder--客户端指定访问IP段
- python 容器类型数据 (str list tuple set dict)
- 背水一战 Windows 10 (75) - 控件(控件基类): FrameworkElement - 基础知识, 相关事件, HorizontalAlignment, VerticalAlignment