在 VS Code 中调试 Go 程序需配置 launch.json 并使用 Delve 调试器:安装 Go SDK(≥1.16)、dlv 和官方 Go 扩展;通过 Debug: Open launch.json 自动生成配置;设置 program、mode、args 等字段;添加断点(含条件断点和日志断点);利用调试面板查看变量、切换 goroutine、控制执行流。
在 VS Code 中调试 Go 程序,核心是正确配置 .vscode/launch.json 并合理设置断点。Go 官方推荐使用 dlv(Delve)作为调试器,VS Code 通过 go 扩展集成它。只要环境就绪、配置得当,调试体验流畅自然。
调试前需确认以下三项已就位:
go install github.com/go-delve/delve/cmd/dlv@latest 安装,完成后执行 dlv version 验证Go 扩展(由 Go Team 维护,图标为蓝色 G)无需手动编写,VS Code 可智能生成适配当前项目的调试配置:
.go 文件(如 main.go)Ctrl+Shift+P(Windows/Linux)或 Cmd+Shift+P(macOS),输入 Debug: Open launch.json
Go → 选择 Launch Package(适用于普通可执行程序)或 Launch Test(用于测试函数).vscode/launch.json,内容类似:{
"version": "0.2.0",
"configurations": [
{
"name": "Launch Package",
"type": "go",
"request": "launch",
"mode": "test", // 或 "auto", "exec", "core"
"program": "${workspaceFolder}",
"env": {},
"args": []
}
]
}
根据实际场景,可调整以下关键字段:
program:指定要调试的入口路径。值为 "${workspaceFolder}" 表示当前工作区根目录(自动识别 main 包);也可写死为 "./cmd/myapp/main.g
o"
mode:"auto"(默认,自动判断)、"exec"(调试已编译的二进制)、"test"(调试 go test)、"core"(分析 core dump)args:传递给程序的命令行参数,例如 ["-port=8080", "-debug"]
env:设置环境变量,如 {"GIN_MODE": "debug"}
dlvLoadConfig:控制变量加载深度,避免大结构体卡顿,常见配置:"dlvLoadConfig": {
"followPointers": true,
"maxVariableRecurse": 1,
"maxArrayValues": 64,
"maxStructFields": -1
}
断点操作简单直观:
Edit Breakpoint → 输入表达式,如 i == 5 或 len(data) > 100
Edit Breakpoint → 选择 Log Message,输入类似 Processing item: {item.Name},执行时只打印不中断F5 或点击侧边栏「运行」→「开始调试」→ 选择配置名称进入调试后,可充分利用 VS Code 的调试面板:
F10(单步跳过)、F11(单步进入)、Shift+F11(单步跳出)、F5(继续)控制执行流fmt.Printf("%v", mySlice) 或调用函数(注意副作用)