使用 VS Code 开发 C# 程序时,如何配置 launch.json

使用 VS Code 开发 C# 程序时,如何配置 launch.json

本文来自于我关于用 VS Code 开发 C# 系列文章。欢迎阅读、点评与交流~
1、如何使用 VSCode 编写 C# 代码?
2、如何用 VS Code + C# Dev Kit 创建类库项目并在主项目中引用它?
3、使用 VS Code 开发 C# 程序时,如何配置 launch.json

在 VS Code 中,.vscode/launch.json调试器配置文件,它定义了如何启动和调试你的程序。对于 C# 项目,它会告诉 VS Code 使用哪个 .NET 调试器、启动哪个程序、如何传递参数等。

下图展示了调试配置中几个核心参数的关系:
核心调试配置 H .NET Core CLR
type: coreclr 请求类型
request: launch 程序入口
program: .../*.dll 按下 F5 启动调试 查找并执行
.vscode/launch.json 配置 执行 preLaunchTask 调用 .NET Core CLI
dotnet build 生成可执行文件
*.dll 附加调试器并运行

🔧 C# 调试核心参数设置

以下是在 C#/.NET Core 环境下 launch.json 配置文件中最关键的参数,你可以根据需要进行修改。

参数 作用与用途 常用值/示例 说明
name 配置名称 ".NET Core Launch (console)" 在调试下拉菜单中显示的名字。
type 调试器类型 "coreclr" 对于 .NET Core 程序,固定为此值。
request 调试请求类型 "launch""attach" launch :启动新进程并调试;attach:附加到已运行进程。
preLaunchTask 调试前任务 "build" 调试 自动执行的任务(如编译),需与 tasks.json 中定义的任务名匹配。
program 程序入口 "${workspaceFolder}/bin/Debug/net8.0/MyApp.dll" 要启动的 .dll 文件路径。必须与项目生成的程序集路径一致。
args 命令行参数 ["arg1", "--option", "value"] 启动程序时传递给它的命令行参数数组。
cwd 工作目录 "${workspaceFolder}" 程序运行时的当前工作目录。
env 环境变量 { "ASPNETCORE_ENVIRONMENT": "Development" } 为调试进程设置环境变量。
console 控制台类型 "integratedTerminal" 控制程序输出位置。internalConsole(调试控制台,默认)或 integratedTerminal(集成终端)。
projectPath 配置调试的项目文件路径 "${workspaceFolder}//.csproj" 指定要调试的项目文件路径

💡 关键须知

  1. C# 项目的特殊性

    • program 路径 :C#/.NET Core 项目调试的是编译后生成的 .dll 文件 ,而不是 .csproj 文件。请确保路径中的目标框架版本 (如 net8.0)和项目名称与实际匹配。
    • launchSettings.json :这是 ASP.NET Core 等项目自身 的启动配置文件,位于 Properties/ 文件夹下,用于定义开发时的启动方式(如URL、环境变量)。launch.json 在调试时可以自动读取并继承其中的部分设置(如环境变量、URL)。
  2. 如何生成与调试

    • 自动生成 :在 VS Code 中打开项目文件夹,进入"运行和调试"视图 (Ctrl+Shift+D),点击"创建 launch.json 文件",然后选择 ".NET Core" 环境,VS Code 会自动生成基础配置。
    • 启动调试 :配置好后,按 F5 键,VS Code 将根据配置启动调试会话。

📝 一个 C# 控制台项目的 launch.json 示例

你可以此为模板,替换 program 等路径中的项目名和框架版本。

json 复制代码
{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "调试 MyConsoleApp",
      "type": "coreclr",
      "request": "launch",
      "preLaunchTask": "build", // 确保 tasks.json 中有名为 "build" 的任务
      "program": "${workspaceFolder}/bin/Debug/net8.0/MyConsoleApp.dll",
      "args": [],
      "cwd": "${workspaceFolder}",
      "console": "integratedTerminal",
      "stopAtEntry": false
    },
    {
      "name": ".NET Core 附加",
      "type": "coreclr",
      "request": "attach",
      "processId": "${command:pickProcess}"
    }
  ]
}
相关推荐
wxin_VXbishe6 小时前
C#(asp.net)学员竞赛信息管理系统-计算机毕业设计源码28790
java·vue.js·spring boot·spring·django·c#·php
mailangduoduo6 小时前
零基础教学连接远程服务器部署项目——VScode版本
服务器·pytorch·vscode·深度学习·ssh·gpu算力
bugcome_com18 小时前
零基础入门C#:一篇搞懂核心知识点
c#
kun2003102921 小时前
如何用Obsidian+VSCode生成文案排版并发布到公众号
ide·vscode·编辑器
程序员敲代码吗21 小时前
如何通过命令行启动COMSOL的参数化、批处理和集群扫描
java·c#·bash
执风挽^1 天前
Python基础编程题2
开发语言·python·算法·visual studio code
缺点内向1 天前
C#: 告别繁琐!轻松移除Word文档中的文本与图片水印
c#·自动化·word·.net
喵叔哟1 天前
06-ASPNETCore-WebAPI开发
服务器·后端·c#
2501_930707781 天前
使用 C# .NET 从 PowerPoint 演示文稿中提取背景图片
c#·powerpoint·.net
初级代码游戏1 天前
套路化编程 C# winform 自适应缩放布局
开发语言·c#·winform·自动布局·自动缩放