引言
2025 年 11 月,微软正式发布 .NET 10。作为长期支持版本(LTS),.NET 8 的性能优化能力才是让开发者真正受益的核心武器。
GitHub Copilot 用户数在 2025 年已突破 1500 万,AI 辅助编程已成常态。然而,代码写得再快,性能跟不上也是白搭。今天我们就来聊聊 .NET 8 中那些能让你的应用性能提升显著的实战技巧。
一、AOT 编译:告别冷启动噩梦
什么是 AOT?
AOT(Ahead-of-Time)编译,简单说就是把代码提前编译成原生机器码,而不是运行时才 JIT 编译。这意味着:
- 启动速度大幅提升(具体效果因项目而异)
- 内存占用更低
- 部署包更小(Linux 上可减少 50%)
实战配置
xml
<!-- 在项目文件中启用 AOT -->
<PropertyGroup>
<PublishAot>true</PublishAot>
</PropertyGroup>
发布命令:
bash
dotnet publish -c Release -r win-x64
适用场景
- 云函数 / Serverless:冷启动敏感场景
- 微服务:快速扩容需求
- CLI 工具:命令行工具,启动要快
注意事项
AOT 虽好,但有限制:
- 反射需要额外配置
- 动态代码生成不支持
- 第三方库兼容性要测试
二、PGO 动态优化:让热点代码飞起来
什么是 PGO?
PGO(Profile-Guided Optimization)是 .NET 8 的杀手锏。它会在运行时收集代码执行数据,然后针对热点路径进行专门优化。
简单理解:JIT 编译器变聪明了,它知道哪些代码被执行最多,就重点优化哪些。
性能提升
根据官方数据:
- 应用吞吐量提升最高 20%
- 尤其适合计算密集型场景
如何启用
默认已开启!.NET 8 中 PGO 是默认启用的动态 PGO,无需额外配置。
想手动控制的话:
xml
<PropertyGroup>
<TieredPGO>true</TieredPGO>
</PropertyGroup>
实战案例
一个简单的 JSON 序列化场景:
csharp
// PGO 会识别这是热点代码
// 自动内联、消除边界检查
var json = JsonSerializer.Serialize(data);
运行次数越多,优化越到位。这就是 PGO 的魅力。
三、AVX-512 支持:512 位向量化运算
什么是 AVX-512?
AVX-512 是 Intel 的高级向量扩展指令集,支持 512 位并行计算。一次处理 8 个 double 或 16 个 int。
.NET 8 的支持
.NET 8 新增对 AVX-512 的完整支持:
csharp
using System.Numerics;
// 512 位向量化运算
var vector = Vector512.Create(1.0f, 2.0f, 3.0f, 4.0f, 5.0f, 6.0f, 7.0f, 8.0f);
性能对比
| 场景 | 传统方式 | AVX-512 | 提升 |
|---|---|---|---|
| 矩阵运算 | 100ms | 25ms | 4x |
| 图像处理 | 200ms | 60ms | 3.3x |
| 科学计算 | 500ms | 150ms | 3.3x |
适用场景
- 图像/视频处理
- 科学计算
- 金融数据分析
四、新的性能监控 API
System.Diagnostics.Metrics
.NET 8 引入了全新的度量 API:
csharp
using System.Diagnostics.Metrics;
var meter = new Meter("MyApp", "1.0");
var counter = meter.CreateCounter<long>("requests.count");
counter.Add(1);
与 OpenTelemetry 集成
csharp
builder.Services.AddOpenTelemetry()
.WithMetrics(b => b.AddMeter("MyApp"));
五、C# 12 新特性:写出更快的代码
主构造函数
csharp
public class UserService(ILogger logger, IUserRepository repo)
{
public User GetById(int id) => repo.FindById(id)!;
}
内联数组
csharp
[System.Runtime.CompilerServices.InlineArray(10)]
public struct Buffer10<T>
{
private T _element0;
}
六、实战优化清单
启动优化
- 启用 AOT 编译(云函数/微服务)
- 使用 PublishTrimmed 裁剪依赖
- IHostedService 做后台初始化
运行时优化
- PGO 默认开启,保持默认即可
- 热点代码使用 Span / Memory
- 接入 OpenTelemetry 监控
数据库优化
- EF Core 8 批量操作
- Compiled Queries
- 连接池合理配置
总结
.NET 8 的性能优化从 AOT 的冷启动优化,到 PGO 的动态优化,再到 AVX-512 的向量化计算,每一项都能在合适的场景下带来显著收益。
关键是要结合自己的业务场景选择合适的优化手段:
- Serverless 场景 - AOT 是必选项
- 高并发服务 - PGO + 连接池优化
- 计算密集型 - AVX-512 + 内联数组
- 长期维护项目 - 监控 API + OpenTelemetry
性能优化是一场持久战,不要追求一步到位。先建立监控,找到瓶颈,再针对性优化。
我是刚子,一个写了六年代码的.NET老程序员。咱们下回见!