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,基本能帮你把问题一条条列出来,还能给出优化后的代码,只是免费的有次数限制,这个月的已经早早用完了。

相关推荐
LDR0067 小时前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术7 小时前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园7 小时前
C++20 Modules 模块详解
java·开发语言·spring
swordbob8 小时前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
小小工匠8 小时前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
源分享8 小时前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.8 小时前
C语言--day30
c语言·开发语言
何以解忧,唯有..8 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
謓泽9 小时前
C语言不是语法,是通往机器的地图。
c语言·开发语言
云水一下9 小时前
从零开始学 PHP 系列(一):PHP 的前世今生与开发环境搭建
开发语言·php