C++调试应依靠工具与方法而非猜测:GDB适用于Linux/macOS命令行,VS调试器适合Windows图形化场景,二者均通过设断点、查变量、看调用栈、单步执行定位问题,关键在于建立清晰调试路径。
C++调试不靠猜,靠工具和方法。GDB适合Linux/macOS命令行环境,Visual Studio调试器则在Windows下更直观高效。两者核心逻辑一致:设断点、查变量、看调用栈、单步执行。关键不是记住所有命令,而是建立清晰的调试路径。
GDB是C++开发者绕不开的底层调试利器,尤其适合服务器程序或无GUI场景。
g++ -g -o myapp main.cpp;不加-g,GDB看不到变量名和源码行gdb ./myapp,运行前用run,带参数就写run arg1 arg2
break main 或 break file.cpp:15next(步入下一行,不进函数)、step(进入函数内部)print x(查变量)、bt(看调用栈)、info registers(查寄存器,排查段错误时有用)gdb ./myapp core加载core dump,输入bt就能看到哪一行触发了SIGSEGVVS不只是IDE,它的调试器对C++支持深度且稳定,尤其适合复杂项目和多线程调试。
i == 100,只在特定值停下;“命中次数”适合循环中第N次触发vec.size()或&obj
&ptr可查看原始内存布局无论用哪个工具,以下习惯能大幅减少无效时间。
call printf("x=%d\n", x)临时打日志;VS里可用OutputDebugStringA输出到“输出”窗口,不影响断点流程watch *ptr监控地址变化;VS开启“地址监视”或编译时加/RTC1(运行时检查栈溢出/未初始化变量)/Zi(生成PDB)和-O1(轻量优化)
,别用-O3,会内联/重排,导致单步“跳行”基本上就这些。工具只是手,真正重要的是你问问题的方式:是“程序崩了”,还是“在foo()返回前,this->data[0]突然变成0”。后者,调试就已经成功了一半。