答案:VS Code通过调试器配置异常捕获可提升调试效率,支持按异常类型设置中断行为。在launch.json中为Node.js设uncaught/caught策略,Python则用exceptionHandling控制raised和uncaught异常的breakMode,结合skipFiles和运行时调整,精准定位问题。

在使用 VS Code 进行开发时,调试是不可或缺的一环。异常捕获设置能帮助你快速定位代码中的错误,尤其是在运行和调试阶段自动中断于异常抛出处。合理配置这些设置,可以极大提升排查问题的效率。
理解异常捕获的基本机制
VS Code 本身不直接执行代码,而是通过调试器(如 Node.js 的调试器、Python 的 debugpy 等)与运行环境交互。异常捕获依赖于调试器的能力和配置。
当你启动调试会话时,可以在“运行和调试”侧边栏中看到“异常”区域,这里列出可配置的异常类型:
- 始终中断:无论是否有 try/catch,遇到该异常就暂停
- 仅在未捕获时中断:只在异常未被 catch 处理时暂停
- 从不中断:忽略该异常,继续执行
常见异常类型包括“Caught Exceptions”(已捕获异常)和“Uncaught Exceptions”(未捕获异常)。
配置 Node.js 项目的异常行为
对于 JavaScript/Node.js 项目,可以通过 launch.json 设置异常策略:
{ "type": "node", "request": "launch", "name": "调试异常", "program": "${workspaceFolder}/app.js", "stopOnEntry": false, "console": "integratedTerminal", "skipFiles": [ "说明:
- "uncaught": true 表示遇到未捕获异常时自动暂停
- "caught": false 表示即使 try/catch 捕获了异常也不中断
若想连已捕获异常也中断,可将 caught 设为 true,便于查看异常源头。
Python 调试中的异常控制
使用 Python 扩展(如 ms-python.python)时,debugpy 支持类似的异常控制。launch.json 中的配置如下:
{ "name": "Python: 当前文件", "type": "python", "request": "launch", "program": "${file}", "console": "integratedTerminal", "justMyCode": true, "exceptionHandling": { "raised": { "include": false, "breakMode": "never" }, "uncaught": { "include": true, "breakMode": "always" } } }其中:
- raised 指所有抛出的异常(包括被捕获的)
- uncaught 指未被捕获的异常
- breakMode 可设为 "never"、"always" 或 "unhandled"
将 raised 的 breakMode 设为 "always" 可在每次 raise 时中断,适合深度调试。
实际使用建议
异常捕获设置应根据调试场景灵活调整:
- 排查未知崩溃时,开启“未捕获异常中断”快速定位错误位置
- 分析异常处理逻辑是否正确,可临时启用“已捕获异常中断”
- 跳过标准库或框架内部异常,可在 skipFiles 中添加路径模式
- 调试异步代码时,注意 Promise 拒绝可能需要额外启用“蓝鸟异常”或类似选项
在 VS Code 的调试视图中,可随时点击“异常”旁边的齿轮图标,修改当前会话的异常策略,无需重启调试。
基本上就这些。掌握异常捕获设置,能让调试更精准高效。不同语言扩展行为略有差异,建议查阅对应调试器文档进一步了解细节。










