为什么不推荐使用Linq?

相信很多.NETer看了标题,都会忍不住好奇,点进来看看,并且顺便准备要喷作者!

这里,首先要申明一下,作者本人也非常喜欢Linq,也在各个项目中常用Linq。

我爱Linq,Linq优雅万岁!!!(PS:顺便吐槽一下,隔壁Java从8.0版本推出的Streams API,抄了个四不像,一点都不优雅,而且很难用。)​

正文

不罗嗦,就一句话:"在性能敏感型应用和追求零内存分配场景不推荐使用Linq!"

让我们用Benchmark结果来说话!!!

这里用一个简单的场景来验证:

  1. 拆分一个String字符串为String[]数组。
  2. 转换数组中的每个String字符串为Int32数值。
  3. 对这些数值求和。

让我们通过BenchmarkDotNet运行性能测试,看看用Linq和不用Linq,这两者之间的性能差异​。

Benchmark代码:

csharp 复制代码
internal class Program
{
    static void Main(string[] args)
    {
        BenchmarkRunner.Run<LinqTest>();
        Console.ReadKey();
    }
}
​
[MemoryDiagnoser, MemoryRandomization]
public class LinqTest
{
    private static readonly string _row = "1,2,3,4,5,6,7,8,9,10";
​
    [Benchmark]
    public void SumUsingLinq()
    {
        int sum = _row.Split(',').Select(int.Parse).Sum();
    }
​
    [Benchmark(Baseline = true)]
    public void SumUsingForLoop()
    {
        var rowSpan = _row.AsSpan();
        int sum = 0;
        for (int i = 0; i < rowSpan.Length; i++)
        {
            if (rowSpan[i] == ',')
            {
                sum += int.Parse(rowSpan.Slice(0, i));
                rowSpan = rowSpan.Slice(i + 1);
                i = 0;
            }
        }
    }
}

Benchmark结果:

从结果中,我们可以看到,不使用Linq的SumUsingForLoop方法,Mean平均值 75.09 ns,Allocated 无;

反观使用了Linq的SumUsingLinq方法,Mean平均值 270.18 ns,Allocated 400 B;

两者之间有约3.5倍的性能差距,而内存分配表现方面也是不使用Linq的占优。

总结:
对于追求 零内存分配(zero-copy)目标 或者 速度敏感型应用,这两种场景,都应该​慎用Linq。因为Linq扩展方法里有大量的判断,甚至还有很多内部对象的创建和内存开销。

PS: 想要坚持写技术文章、写博客、写公众号,真的很难。

相关推荐
大尚来也10 天前
从调度到实时:Linux 下 DolphinScheduler 驱动 Flink 消费 Kafka 的实战指南
c#·linq
步步为营DotNet11 天前
深度解析.NET中LINQ的延迟执行:提升性能与资源管理的关键
.net·solr·linq
左手厨刀右手茼蒿11 天前
Flutter for OpenHarmony: Flutter 三方库 hashlib 为鸿蒙应用提供军用级加密哈希算法支持(安全数据完整性卫士)
安全·flutter·华为·c#·哈希算法·linq·harmonyos
lucky670712 天前
Laravel7.X十大核心特性解析
spring boot·kafka·linq
小程故事多_8013 天前
详解Kafka重平衡与分区重分配,核心差异、原理及实操辨析
分布式·kafka·linq
码客研究员16 天前
Kafka(05)搭建高可用Kafka集群:从三台服务器开始
服务器·kafka·linq
HrxXBagRHod19 天前
探索一维声子晶体结构带隙仿真模型
linq
你这个代码我看不懂23 天前
@RefreshScope刷新Kafka实例
分布式·kafka·linq
Go高并发架构_王工25 天前
SpringBoot整合Kafka:构建高效消息驱动应用
spring boot·kafka·linq
闻哥25 天前
Kafka核心优化机制:Batch+Request底层原理与缓冲池设计深度解析
java·spring boot·面试·kafka·linq·batch