写点什么

.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:002430
用户头像

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

关注

评论

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

队列的链式表示和实现

工程师日月

算法 7月月更

还在为处理事务烦恼吗,要不试试Spring是如何处理业务的

Java学术趴

7月月更

zookeeper-认识watcher

zarmnosaj

7月月更

解读《深入理解计算机系统(CSAPP)》第12章并发编程

小明Java问道之路

Java 后端 并发 csapp 7月月更

通过Dao投票STI的销毁,SeekTiger真正做到由社区驱动

鳄鱼视界

Android ANR和OOM

沃德

android 程序员 7月月更

SAP Fiori 的附件处理(Attachment handling)

汪子熙

SAP Fiori SAP UI5 ui5 7月月更

jQuery 操作元素

Jason199

jquery js 7月月更

通过Dao投票STI的销毁,SeekTiger真正做到由社区驱动

股市老人

关于目前流行的 Redis 可视化管理工具的详细评测

宁在春

redis 7月月更 Redis 可视化工具

jQuery 的节点操作

Jason199

jquery js 7月月更

【Docker 那些事儿】容器网络(上篇)

Albert Edison

Docker Kubernetes 容器 云原生 7月月更

常见链表题及其 Go 实现

宇宙之一粟

链表 7月月更

开发第一个Flink应用

程序员欣宸

Java flink 7月月更

软核微处理器

贾献华

7月月更

分库分表

ES_her0

7月月更

初学者如何快速的上手Linux命令,这34条新手必会的命令一定得会!

wljslmz

Linux 7月月更

Block 的分类

NewBoy

ios 前端 移动端 iOS 知识体系 7月月更

Android热更新调研汇总

沃德

android 程序员 7月月更

JavaScript DOM编程艺术笔记

程序员海军

前端 DOM 7月月更

mysql数据表查询

乌龟哥哥

7月月更

【LeetCode】滑动窗口的平均值Java题解

Albert

LeetCode 7月月更

SDL图像显示

柒号华仔

7月月更

mysql进阶(六)模糊查询的四种常见用法介绍

No Silver Bullet

MySQL 7月月更 模糊查询

Pyodide 中实现网络请求的 3 种方法

OpenHacker

Python pyodide

LeetCode 242:有效的字母异位词

武师叔

7月月更

【萌新解题】三数之和

面试官问

面试 LeetCode

Android实现无序树形结构图,类似思维导图和级联分层图(无序,随机位置)

芝麻粒儿

android 7月月更

【愚公系列】2022年7月 Go教学课程 012-强制类型转换

愚公搬代码

7月月更

深度学习-多维数据和tensor

AIWeker

7月月更 多维数据

函数初认识-上

芒果酱

C语言 7月月更

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