问题
如下图,当我们使用GDB调试core时,打印map时只能看到map结构的信息,而不能查看到map节点的值。
现有方案
当然,从网上还是可以找到一些打印STL的解决方案,其中比较简单实用的一种方法是使用 gdb-stl-views
- 使用介绍:https://blog.csdn.net/xp178171640/article/details/123713783
- 官方地址:https://sourceware.org/gdb/wiki/STLSupport
使用 gdb-stl-views 打印的结果如下:
遗留问题
然而,虽然使用 gdb-stl-views 可以一定程度上面打印出来map的值,但是这种方法依然存在一些问题:
- 能打印的数值形式比较有限。例如上面的实例中map的key节点是包含指针的结构体,使用 gdb-stl-views 能打印出来结构体的内容,不能方便打印结构体指针的值;
- 使用 gdb-stl-views 只能遍历打印所有节点,不能按照树的左右节点打印值
- gdb-stl-views 的打印效率很低(在本次示例中,因为core文件有70+G,平均1秒只能打印一个节点)
新方案
以查找目标key值= 0358822202 为例
-
先找到Map的根节点,并打印根节点的值,其中stock_account是map比较函数的key字段,比较函数为strcmp
-
因为 “0358822202” < “0607047xxxxxx”,所以第二次打印根节点的左节点
-
因为“014617xxxxxxxx”<“0358822202”,所以向右节点查找
-
以此类推,最终查找到目标节点,key=0358822202
方法来源
新的方法参考自 gdb-stl-views
的实现