vscode + gdb 如何调试 含嵌套的STL

GDB调试C++时,可能会遇到无法打印STL内容的情况,这为我们带来了很多困扰。本文,教你如何使用vscode配合gdb轻松破解这一问题。

首先,从该网站,下载好需要的python小工具。
(没有svn 先yum / apt install svn)

svn co svn://gcc.gnu.org/svn/gcc/trunk/libstdc++-v3/python

运行之后,当前的bash运行目录下会下载好一个python/目录,你可以把它移动到需要的地方(我个人移动到\usr\local\)。
然后,修改~/.gdbinit的内容,粘贴如下即可:

python
import sys
sys.path.insert(0, '/usr/local/python')
from libstdcxx.v6.printers import register_libstdcxx_printers
register_libstdcxx_printers (None)
end

再然后,用你的vscode 运行代码,注意需要添加一些标志符,如果是CMake的话,可以参考如下:set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g -ggdb3")

同时注意修改launch.json,我给了一份参考文件,特别注意setupCommands中要打开pretty-printing

{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "c++ Launch",
            "type": "cppdbg",
            "request": "launch",
            "program": "/home/...", // 需要执行的文件位置 ycsb"
            "args": [
                ], // 输入的参数
            "stopAtEntry": true,
            "cwd": "/home/.../", // 当前运行的位置
            "environment": [],
            "externalConsole": false,
            "MIMode": "gdb",
            "setupCommands": [
                { 
                    "text": "-enable-pretty-printing", 
                    "description": "enable pretty printing", 
                    "ignoreFailures": true }
            ],
            "preLaunchTask": "bench_tpcc",  //与tasks.json 的label项目同名
            // "miDebuggerPath": "/usr/bin/gdb"
            "targetArchitecture": "x86_64",
        }
    ]
}

最后,激动的心颤抖的手。即使是嵌套的STL也可以轻松调试咯!
我的contents是一个如下定义std::map<std::string, std::map<double, int> > contents;
在这里插入图片描述

参考链接:https://stackoverflow.com/questions/11606048/how-to-pretty-print-stl-containers-in-gdb

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
VSCode提供了集成的调试工具,其中包括对GDB的支持。要在VSCode中使用GDB进行调试,首先需要配置调试器。可以通过安装C/C++插件来获得对GDB的支持。然后,按照以下步骤进行配置: 1. 打开VSCode并打开要调试的项目。 2. 在左侧的活动栏中,点击调试图标(调试镜像)以打开调试视图。 3. 在调试视图中,点击顶部工具栏中的"齿轮"图标,这将打开"launch.json"文件。 4. 在"launch.json"文件中,可以看到一个 "configurations" 数组,其中包了不同的调试配置。在这里,我们需要添加一个GDB配置。 5. 在 "configurations" 数组中添加以下配置: ``` { "name": "GDB", "type": "cppdbg", "request": "launch", "program": "${workspaceFolder}/your_program", "miDebuggerPath": "gdb", "miDebuggerArgs": "-g", "cwd": "${workspaceFolder}" } ``` 确保将 "your_program" 替换为你要调试的程序的路径。 6. 保存并关闭 "launch.json" 文件。 7. 现在,你可以在VSCode中点击调试视图左侧的绿色播放按钮来启动GDB调试器。 8. 在调试器启动后,你可以设置断点,单步执行代码,查看变量和堆栈等。 通过上述步骤,你就可以在VSCode中使用GDB进行调试了。请确保你的项目已经正确配置,并且你已经正确安装了GDB。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [一文掌握vscode远程gdb调试](https://blog.csdn.net/zong596568821xp/article/details/124338072)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值