by Oliver
8. November 2017 09:00
This is a digitalized version of my session notes from the conference.
Key Questions
- How fast is it?
- How fast could it be?
- How fast should it be?
Always measure your gains – which implies you need to measure your current performance.
Allocations Cost – Sometimes A Lot
Here's an example from Hyperion (fork of Wire):
original code – allocates a new byte array on every call
data:image/s3,"s3://crabby-images/b9bf0/b9bf04b21ef74c1f21fabbee22eaa0c6d1e7eb88" alt="bitcon bitcon"
optimized code – reuses a byte array from a pool
data:image/s3,"s3://crabby-images/de119/de119666e27ec4f3c216e251de8f98e23203afd4" alt="bitcon-no-alloc bitcon-no-alloc"
What are the gains of this small change?
data:image/s3,"s3://crabby-images/104c5/104c50b68a1744060eb9e2a18863b80893ac3b41" alt="perf-table perf-table"
Optimizations like this one pay off especially in low-level code or inside of libraries that will be consumed by third parties. As always – first measure, then optimize.
Tools for the performance minded
- BenchmarkDotNet: a .NET benchmarking framework
- marten: async document database and/or event store
- Hyperion: a high performance polymorphic serializer for the .NET framework, built for Akka.NET
- Jil: Fast .NET JSON (De)Serializer, Built On Sigil
- protobuf-net: Protocol Buffers library for idiomatic .NET
- Microsoft Bond: cross-platform framework for cross-language de/serialization with powerful generic mechanisms (this is not your go-to tool when you just want to de/serialize some data quickly ;-) - it's a whole framework)
Have fun and stay focused!