贝利信息

c# AggressiveInlining 和高并发下的性能优化

日期:2026-01-05 00:00 / 作者:幻夢星雲
多数情况下没用,甚至有害;.NET JIT 对 AggressiveInlining 的内联决策受函数大小、控制流复杂度、异常处理等硬性限制,高并发下更关键的是减少锁争用、避免内存分配和缓存伪共享。

AggressiveInlining 在高并发场景下真的有用吗

多数情况下没用,甚至有害。.NET JIT 对 AggressiveInlining 的实际内联决策仍受函数大小、控制流复杂度、是否含异常处理等硬性限制;高并发下更关键的是减少锁争用、避免内存分配和缓存行伪共享,而非强行把一个 20 行带 try/catch 的方法塞进调用点。

哪些函数适合加 [MethodImpl(MethodImplOptions.AggressiveInlining)]

仅适用于极简、无分支、无对象分配、无 P/Invoke、无虚调用的热路径辅助函数。典型如:

一旦函数体含 newlockawaityield return 或任何非 trivial 的条件跳转,JIT 会直接忽略该标记。

高并发下比 AggressiveInlining 更有效的优化点

真正影响吞吐量的是内存访问模式与同步原语选择:

public struct Counter
{
    [FieldOffset(0)] private long _value;
    [FieldOffset(16)] private long _padding; // 防止与相邻字段共享 cache line
}

如何验证 AggressiveInlining 是否生效

不能只看代码有没有加标记,必须实测生成的汇编:

很多团队花时间给错误的方法加 AggressiveInlining,却没发现瓶颈其实在 HttpClient 的连接复用率或 JSON 序列化时的字符串拼接上。