如何用 VS Code + C# Dev Kit 创建类库项目并在主项目中引用它?

如何用 VS Code + C# Dev Kit 创建类库项目并在主项目中引用它?

1. 准备工作

确保已安装:

  • C# Dev Kit 扩展
  • .NET SDK (运行 dotnet --version 确认)

2. 创建解决方案和项目

方式一:使用命令行创建

bash 复制代码
# 1. 创建解决方案目录
mkdir MySolution
cd MySolution

# 2. 创建解决方案
dotnet new sln -n MySolution

# 3. 创建控制台主项目
dotnet new console -n ConsoleApp

# 4. 创建类库项目
dotnet new classlib -n ClassLibrary

# 5. 将项目添加到解决方案
dotnet sln add ConsoleApp/ConsoleApp.csproj
dotnet sln add ClassLibrary/ClassLibrary.csproj

# 6. 添加项目引用
dotnet add ConsoleApp/ConsoleApp.csproj reference ClassLibrary/ClassLibrary.csproj

方式二:使用 VS Code GUI 创建

  1. 打开命令面板 (Ctrl+Shift+P)

  2. 创建解决方案

    复制代码
    .NET: Create New Solution
  3. 选择项目模板

    • 先选择 "Console Application"
    • 命名项目为 ConsoleApp
  4. 再添加类库项目

    • 右键解决方案 → "Add New Project"
    • 选择 "Class Library"
    • 命名项目为 ClassLibrary

3. 项目结构

完成后目录结构应如下:

复制代码
MySolution/
├── MySolution.sln
├── ConsoleApp/
│   ├── ConsoleApp.csproj
│   ├── Program.cs
│   └── ...
└── ClassLibrary/
    ├── ClassLibrary.csproj
    ├── Class1.cs
    └── ...

4. 配置项目引用

如果使用命令行已添加引用,跳过此步

如果需要在 GUI 中添加引用:

  1. 打开解决方案视图(左侧边栏)
  2. 右键 ConsoleApp 项目 → "Add Project Reference"
  3. 勾选 ClassLibrary 项目

或者在 ConsoleApp.csproj 中手动添加:

xml 复制代码
<ItemGroup>
  <ProjectReference Include="../ClassLibrary/ClassLibrary.csproj" />
</ItemGroup>

5. 编写代码示例

ClassLibrary/Class1.cs

csharp 复制代码
namespace ClassLibrary
{
    public class Calculator
    {
        public int Add(int a, int b) => a + b;
        public int Multiply(int a, int b) => a * b;
    }
}

ConsoleApp/Program.cs

csharp 复制代码
using ClassLibrary;

var calculator = new Calculator();
Console.WriteLine($"3 + 5 = {calculator.Add(3, 5)}");
Console.WriteLine($"3 * 5 = {calculator.Multiply(3, 5)}");

6. 构建和运行

方法一:使用 VS Code

  1. F5 直接运行(已配置好调试)
  2. 或使用命令面板执行 .NET: Run Project

方法二:使用命令行

bash 复制代码
cd ConsoleApp
dotnet run

7. 调试配置

VS Code 会自动生成 .vscode/launch.json,配置类似:

json 复制代码
{
  "configurations": [
    {
      "name": ".NET Core Launch (console)",
      "type": "coreclr",
      "request": "launch",
      "preLaunchTask": "build",
      "program": "${workspaceFolder}/ConsoleApp/bin/Debug/net8.0/ConsoleApp.dll",
      "args": [],
      "cwd": "${workspaceFolder}/ConsoleApp"
    }
  ]
}

常见问题解决

  1. 找不到命名空间

    • 确保类库是 public 访问级别
    • 重新构建:dotnet build
  2. 项目引用未生效

    bash 复制代码
    # 清理并重新构建
    dotnet clean
    dotnet build
  3. VS Code 未检测到更改

    • 重启 VS Code
    • 重新加载窗口 (Ctrl+Shift+P → "Developer: Reload Window")

建议的工作流程

  1. 始终从解决方案根目录打开

    bash 复制代码
    code MySolution
  2. 使用解决方案视图管理项目

    • 添加/移除项目
    • 管理项目引用
    • 查看项目依赖
  3. 利用 C# Dev Kit 功能

    • 测试资源管理器:运行单元测试
    • 依赖关系图:可视化项目依赖
    • IntelliCode:AI 辅助编码

这样你就有了一个完整的工作环境,可以在类库中编写共享代码,在控制台程序中使用它。

相关推荐
Wenweno0o2 天前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
chenjingming6662 天前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
cch89182 天前
Python主流框架全解析
开发语言·python
不爱吃炸鸡柳2 天前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
十五年专注C++开发2 天前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射
Momentary_SixthSense2 天前
设计模式之工厂模式
java·开发语言·设计模式
‎ദ്ദിᵔ.˛.ᵔ₎2 天前
STL 栈 队列
开发语言·c++
勿忘,瞬间2 天前
数据结构—顺序表
java·开发语言
张張4082 天前
(域格)环境搭建和编译
c语言·开发语言·python·ai
weixin_423533992 天前
【Windows11离线安装anaconda、python、vscode】
开发语言·vscode·python