写点什么

.NET Core 运行时和基础类库性能提升

  • 2017-06-27
  • 本文字数:1603 字

    阅读完需:约 5 分钟

微软宣布改进了.NET Core 运行时和基础类库的性能。虽然没有像改进ASP.NET Core 的性能那样大肆宣传,但这些改进同样重要。

其中,以下10 个方面的变化比较显著:集合、LINQ、压缩、加密、数学运算、序列化、文本处理、文件I/O、网络和并发。至于任何一组性能变化如何影响具体的应用程序则取决于具体的使用模式。下面的讨论只列出了一些要点,让你对这些改进有一个大概的了解。其中有许多变化是基于开源Pull Request 请求。这样,一些对于微软而言因为总体影响极小而不值得实现的重要修改就可以实现了。而这些修改对于很大一部分开发人员而言相当重要。

集合几乎在任何应用程序中都有广泛的应用。许多操作都通过简化集合或降低复杂度得到了改进。其中有些改进得益于减少开销,如简化操作实现更好的内联,或者减少指令数量。SortedSet 的构造函数得到了修复,因为最初该构造函数采用了一种简单的方式编写,在处理重复时可扩展性不是很好。SortedSet 的Min 和 Max 不需要遍历整棵树。List.Add 的速度更快了。不只是System.Collections.Generic 得到了改进,其他命名空间如System.Collections.Concurrent 也得到了改进。 ConcurrentQueue 和ConcurrentBag 基本上重写了。LINQ 用户应用仅从集合的改进就可以感受到性能的提升了。

此外,LINQ 本身的性能也是一个改进方面。为了减少内存分配的数量和大小以及简化算法,.NET Core 的许多操作符都重写了。例如,Enumerable.Concat 可以确保串联多个Enumerable 时线性增长,而不是指数增长。ToList 和Select 操作符经过了简化,减少了内存分配和委托及接口的使用,同时将字段读写最小化,避免了复制。Enumerable.ToArray 现在对内部缓冲区的管理也更好了。

与集合和LINQ 操作内存不同,压缩通常是受CPU 限制。例如,DeflateStream 现在使用了一个原生解压库。该原生解压库也经过了优化。

在加密方面,SHA256.Create 使用了一种原生实现,如Windows 上的CNG,或Unix 上的OpenSSL。

数学运算操作在操作BigInteger 时的性能得到了提升。

二进制序列化是CPU、数据和内存密集型的。.NET Core 2.0 增加了BinaryFormatter,并允许O(N) 算法在切换到O(N2) 算法之前使用更长的时间。现在,较大的序列化输入可以更快地处理了。

对于文本处理,Regex.IsMatch 在内存分配方面更高效了,而且,由于数据缓存方式的变化,垃圾收集也更高效了。WebUtility.UrlDecode 不再对输入做实际上并不需要的解码了。微软针对一些内置的Encoding 派生类型进行了循环优化。

微软对字符串操作也做了许多改进。Enum.Parse 在内存使用方面更高效了,所以垃圾收集也更高效了。各种ToString 方法也经过了改进。String 类本身的方法也经过了改进,如IndexOf 和StartsWith。考虑到字符串在应用程序中使用比较多,这样的改进应该会产生巨大的影响。

文件I/O 经过了改进。使用异步读写的FileStreams 现在效率更高了。

底层网络协议栈经过了改进。异步套接字现在允许此类操作实际上同步完成,从而避免异步完成的开销。这些类型的变化对于使用套接字原语的上层函数有很大的影响。与上层网络类如NetworkStream 和 SslStream 相关的工作也是一个改进的来源。

对并发与并行的修改工作已经开展。许多.NET 应用程序使用ThreadPool 类。例如,QueueUserWorkItem 使用一个同步控制和内存分配更少的队列取代了全局队列,大大减少了垃圾收集工作。对于类似SpinLock 这样的同步原语,相关的改进工作一直在进行。SpinLock.TryEnter 经过了改进,当无法立即获得锁时,它会更快地失败。对于使用这个类的热门执行路径,这项改进带来了巨大的性能提升。

在这一轮的性能改进工作中,有大约1000 个Pull Request 被合并进来,而需要完成的工作还有许多。总之,在增加基于性能的API 及改进现有库方面,性能提升有更高的优先级。

BenchmarkDotNet 对这些修改做了一些独立的测试

查看英文原文.NET Core Runtime and Base Class Library Performance

2017-06-27 19:002920
用户头像

发布了 1008 篇内容, 共 438.0 次阅读, 收获喜欢 346 次。

关注

评论

发布
暂无评论
发现更多内容

彩色图像色彩空间原理(理论篇—6)

不脱发的程序猿

机器视觉 图像处理 色彩空间原理

单步调试理解webpack里通过require加载nodejs原生模块实现原理

汪子熙

前端 前端开发 webpack 28天写作 12月日更

Python 的元类设计起源自哪里?

Python猫

Python ruby

王者商城异地多活设计

天天向上

架构实战营

直播预告|百万人观看无卡顿!京东云CDN支撑直播丝般顺滑

京东科技开发者

CDN 直播

如何给产品做拉新?

石云升

AARRR 产品思维 28天写作 产品增长 12月日更

2021的科技卦象·兑·一场“双碳”催化雨

脑极体

040022-week7-design

InfoQ_70156470130f

视频知识点(6)- MPEG vs JPEG

liuzhen007

28天写作 12月日更

蓝绿发布、滚动发布、灰度发布

xcbeyond

灰度发布 28天写作 12月日更 蓝绿发布 滚动发布

前端开发:Mac OS环境下的通过对Chrome浏览器设置SameSite解决跨域请求方法

三掌柜

28天写作 12月日更

PassJava 开源 (四):整合MyBatis-Plus实现CRUD

悟空聊架构

mybatis 28天写作 passjava 悟空聊架构 12月日更

在线问诊初体验

mtfelix

28天写作

绩效沟通准备

搬砖的周狮傅

绩效管理

Dubbo 框架学习笔记十

风翱

dubbo 12月日更

【架构实战营】模块七作业

liu🍊

.NET6新东西--模式匹配中的Extended Property Patterns

喵叔

28天写作 12月日更

盘一盘Java中的abstract和interface

李子捌

28天写作 21天挑战 12月日更

架构营模块七作业

GTiger

架构实战营

DDD领域驱动实战(二)-限界上下文(bounded context)

JavaEdge

12月日更

Prometeus 2.32.0 新特性

耳东@Erdong

Prometheus 28天写作 12月日更

Kafka的Topic和Partition是不是有个数限制?

Kafka中文社区

PassJava 开源 (三):快速生成前后端代码

悟空聊架构

SpringCloud 28天写作 passjava 悟空聊架构 12月日更

如何设计异地多活架构

天天向上

架构实战营

管理文化

圣迪

管理 文化 强势文化 弱势文化

性能分析之TPS从300到750的过程

zuozewei

性能测试 性能分析 12月日更

leetcode 206 反转链表

好吃不贵

分布式数据缓存中的一致性哈希算法

程序员历小冰

缓存 一致性哈希 28天写作 12月日更

盘点2021|「避坑宝典」为大家分享一下笔者在2021年所遇到“匪夷所思”的Bug趣事(上)

码界西柚

2021年展望 2021年度技术盘点与展望 盘点2021 避坑宝典

22《重学JAVA》--字节流

杨鹏Geek

Java25周年 28天写作 12月日更

k8s daemonset controller源码分析

良凯尔

源码 Kubernetes 源码分析 源码解析 #Kubernetes#

.NET Core运行时和基础类库性能提升_.NET_Michael Stiefel_InfoQ精选文章