Ubuntu C++调试有哪些方法
Ubuntu 下可用的 C++ 调试方法概览

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
在 Ubuntu 上调试 C++ 程序,其实选择相当丰富。从最底层的命令行工具到现代化的集成环境,都能帮你精准定位问题。简单来说,可以归为这么几类:
- 命令行调试器:这是基本功。GDB 是经典且通用的选择,而 LLDB 作为 LLVM 生态的一部分,命令与 GDB 高度近似,上手几乎无门槛。
- 图形化与 IDE:如果你更习惯可视化的操作,像 Visual Studio Code(搭配 C/C++ 扩展)、CLion、Eclipse CDT 等工具,能提供断点、变量和调用栈的可视化窗口,实现一键运行和调试。
- 核心转储分析:程序突然崩溃了怎么办?让它生成一个 core dump 文件,然后用调试器进行离线分析,相当于“现场取证”。
- 远程与嵌入式调试:当你的程序跑在远程服务器或嵌入式设备(比如 Android)上时,可以通过 LLDB 等工具连接过去,加载符号并映射源码路径,实现远程调试。
命令行调试 GDB 与 LLDB 快速上手
无论选择哪个工具,第一步都至关重要:编译时务必加入调试信息。使用 -g 选项是必须的;为了获得最直观的调试体验,通常建议同时关闭编译器优化,比如加上 -O0。一个标准的编译命令是这样的:g++ -g -O0 main.cpp -o main。
接下来,看看两大命令行调试器的基本操作流程:
- GDB 常用流程与命令:
- 启动:
gdb ./main - 断点:
break main或break main.cpp:10 - 运行:
run [args] - 单步:
next(跳过函数调用)/step(进入函数) - 继续:
continue - 打印:
print var - 栈回溯:
backtrace(简写bt) - 退出:
quit
- 启动:
- LLDB 常用流程与命令(与 GDB 非常相似):
- 启动:
lldb ./main - 设置断点:
b main或breakpoint set --file main.cpp --line 10 - 运行:
run - 单步:
n/s - 继续:
c - 打印:
print expr或frame variable - 栈回溯:
bt - 退出:
quit
- 启动:
有个好消息是,LLDB 和 GDB 的命令存在大量一一对应的关系,从 GDB 转过来几乎没什么成本。不过,在应对复杂项目或需要脚本化调试任务时,LLDB 的脚本能力通常被认为更灵活一些。
图形化与 IDE 调试
对于追求效率的开发者,图形化界面无疑是更友好的选择。
- Visual Studio Code
- 首先,安装 VS Code 和官方的 Microsoft C/C++ 扩展。
- 生成构建任务:按下
Ctrl+Shift+P,输入并选择 “Configure Default Build Task”,然后选择 “g++ build active file”。这会在项目下生成一个tasks.json文件。 - 配置调试:按下
F5,选择环境 “C++ (GDB/LLDB)”,这会生成launch.json文件。你需要关注的配置字段包括program(可执行文件路径)、args(程序参数)、MIMode(指定 gdb 或 lldb)、miDebuggerPath(调试器路径)和preLaunchTask(启动调试前运行的任务)。 - 配置好后,直接在代码行号左侧点击设置断点,按
F5启动调试,就可以使用顶部的调试工具栏进行单步执行、继续、查看变量和调用栈了。
- CLion / Eclipse CDT
- 这两款 IDE 直接内置了对 GDB/LLDB 的深度集成支持。它们不仅提供直观的断点、变量、内存和寄存器视图,还与 CMake/Makefile 等构建系统有良好的集成,非常适合管理大型工程。
高级场景与技巧
掌握了基础,再来看看那些能解决棘手问题的进阶手段。
- 核心转储分析
- 开启与生成:在终端执行
ulimit -c unlimited取消 core 文件大小限制。当程序崩溃后,会在当前目录生成一个(通常名为core的)转储文件。 - 分析:使用
gdb ./main core或lldb ./main -c core加载转储文件。进入后,立即使用bt查看崩溃时的调用栈,再结合frame和print命令定位具体问题。
- 开启与生成:在终端执行
- 远程/嵌入式调试(以 LLDB 为例)
- 连接远程平台:例如连接 Android 设备:
platform select remote-android;platform connect unix-abstract-connect:///data/local/tmp/debug.sock。 - 附加进程:
attach。 - 设置源码映射:如果编译环境和本地环境路径不同,需要映射:
settings set target.source-map <编译时源码路径> <本地源码路径>。 - 加载未剥离符号:为了看到有意义的函数名和变量,加载未剥离符号的库:
target symbols add <未剥离的 .so 文件>。之后就可以像本地调试一样设置断点和查看变量了。
- 连接远程平台:例如连接 Android 设备:
- 条件断点与表达式求值
- 这在排查特定条件下的 Bug 时非常有用。在 LLDB 中设置条件断点:
b main if some_var == 10。你甚至可以在运行时动态求值或修改变量:expr some_var = 42。
- 这在排查特定条件下的 Bug 时非常有用。在 LLDB 中设置条件断点:
- 调试优化相关
- 需要警惕的是,发布构建(
-O2/-O3)会进行大量优化,可能导致变量被优化掉、单步执行顺序混乱。因此,调试时优先使用-O0 -g。如果必须在优化下调试,可以尝试配合-fno-omit-frame-pointer等编译器选项来提升可调试性。
- 需要警惕的是,发布构建(
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Java编译命令在CentOS怎么用
在CentOS上使用Ja va编译命令 想在CentOS系统上编译Ja va程序?这事儿其实不难,但第一步得先把“家伙事儿”准备好——也就是Ja va开发工具包(JDK)。如果你的系统里还没装JDK,别急,跟着下面这几步走,几分钟就能搞定。 第一步:安装JDK 首先,打开你的终端。接下来,最常用的做
如何在CentOS上进行Java编译
在CentOS上编译Ja va程序:从环境搭建到“Hello, World!” 想在CentOS系统上玩转Ja va开发?这事儿其实没想象中那么复杂。核心就两步:先把Ja va开发环境搭起来,然后通过命令行让代码跑起来。下面这份手把手的指南,能帮你快速走通这个流程。 第一步:安装Ja va开发工具包
centos下如何交叉编译golang程序
在CentOS系统下交叉编译Go程序 你是否需要在CentOS服务器上开发Go应用,并希望将其部署到Windows、macOS或其它Linux发行版上运行?通过交叉编译技术,你可以轻松地在CentOS环境中生成适用于多种操作系统和CPU架构的可执行文件。实现这一目标的关键在于灵活运用Go语言内置的环
SpringBoot如何查看与SpringCloud的对应版本
1、访问Spring官方网站 要获取最权威的版本对应信息,最直接的办法就是访问Spring的官方项目网站。通常,你只需要在页面上找到并点击查看版本的链接即可。 2、解读返回的JSON元数据 访问后,网站会返回一份结构清晰的JSON数据,里面包含了构建信息、Git提交记录,以及我们最关心的——各个组件
Nacos配置中心与本地代码工程配置文件之间的优先级关系详解
一、核心原理:配置是如何加载的? 要深入理解Nacos配置中心与本地配置的优先级关系,必须首先掌握Spring Cloud应用启动时配置加载的完整流程。整个过程可以清晰地划分为两个关键的上下文阶段: 1 Bootstrap Context(引导上下文) 引导上下文会在主应用上下文之前完成初始化,是
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

