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

相关推荐
山峰哥28 分钟前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
灰子学技术41 分钟前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
二十雨辰1 小时前
[python]-AI大模型
开发语言·人工智能·python
Yvonne爱编码1 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚1 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
你这个代码我看不懂1 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言
杜子不疼.1 小时前
CANN_Transformer加速库ascend-transformer-boost的大模型推理性能优化实践
深度学习·性能优化·transformer
pas1362 小时前
41-parse的实现原理&有限状态机
开发语言·前端·javascript
ujainu2 小时前
Flutter + OpenHarmony 实现无限跑酷游戏开发实战—— 对象池化、性能优化与流畅控制
flutter·游戏·性能优化·openharmony·endless runner
bugcome_com2 小时前
零基础入门C#:一篇搞懂核心知识点
c#