C#性能优化随记

2019年我在用C#重新influxdb内核后优化性能时发过几篇性能优化的文章,最近又发现了几处瓶颈,在此记录一下。

1. 集合处理时可以使用Parallel并发处理来提高性能

程序内部的集合类型普遍采用了Concurrent并发安全的,在写入接口收到一组数据时(Dictionary<点key, values>),之前的做法是foreach()遍历处理,现在修改为Parallel.Foreach()处理,Parallel会根据CPU的核心数开辟并发数,测试下来一个177M的wal文件写入从22分钟缩短到了3分6秒,性能提高了6倍。

2. 链表结构性能低下,建议使用集合(List)

接近了问题1后,用性能探查发现50%的CPU消耗在了一个不起眼的链表结构上,百度一下发现是链表结构的内存访问性能差,不如集合这种直接内存索引的方式,修改后几乎见不到这部分CPU消耗了。

3. 学会使用性能探查器

用性能探查器记录的CPU数据需要在图上框选一段时间,否则看到的数据就是程序初始运行的CPU占用,而不是程序长时间运行的CPU占用。看到CPU占用后,找到热点代码就可以发现问题了。我的问题1、2都是这么发现的。

4. 用好Copilot

最近一有问题就先问Copilot,基本能帮你把问题一条条列出来,还能给出优化后的代码,只是免费的有次数限制,这个月的已经早早用完了。

相关推荐
JAVA面经实录9173 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
周杰伦fans4 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
Bat U6 小时前
JavaEE|多线程初阶(七)
java·开发语言
谭欣辰6 小时前
C++ 排列组合完整指南
开发语言·c++·算法
foundbug9997 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
XDH_CS7 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql
小短腿的代码世界8 小时前
Qt实时盈亏计算深度解析:从持仓数据到动态盈亏展示
开发语言·qt
小康小小涵8 小时前
基于ESP32S3实现无人机RID模块底层源码编译
linux·开发语言·python
lzjava20248 小时前
Python的函数
开发语言·python