Steve Gordon
Turbocharged: Writing High-Performance C# and .NET Code
#1about 2 minutes
Defining performance metrics for .NET applications
Performance is defined by three key metrics: execution time, throughput, and memory allocations, which influence garbage collection frequency.
#2about 1 minute
Adopting a scientific approach to code optimization
Follow a simple, iterative cycle of measuring with data, optimizing a small part of the code, and then measuring again to validate improvements.
#3about 2 minutes
Choosing the right tools for performance measurement
Use tools like Visual Studio diagnostic tools for profiling and Benchmark.NET for precise micro-benchmarking of specific code paths.
#4about 2 minutes
Getting started with Benchmark.NET for micro-benchmarking
Benchmark.NET is an open-source library that provides high-precision measurements for small units of code by handling warm-up and statistical analysis.
#5about 3 minutes
Understanding Span<T> for efficient memory operations
Span<T> provides a type-safe, read/write view over a contiguous region of memory, such as arrays or stack-allocated memory, without new allocations.
#6about 4 minutes
Using Span<T> slicing to optimize array operations
Slicing a span creates a new view over a portion of the original data in constant time, avoiding the overhead of creating new arrays and copying data.
#7about 2 minutes
Parsing strings without allocations using ReadOnlySpan<char>
Create a `ReadOnlySpan<char>` from a string to parse it by slicing, which avoids creating new substring allocations and reduces memory pressure.
#8about 3 minutes
Navigating Span<T> limitations with Memory<T>
Since `Span<T>` is a stack-only `ref struct`, use the `Memory<T>` type in heap-based scenarios like async methods, then get a span from it when needed.
#9about 4 minutes
Case study: Optimizing S3 object key generation
A practical example shows how replacing string arrays and regex with `Span<T>` and stack allocation dramatically reduced memory allocations from 1KB to 192 bytes per operation.
#10about 2 minutes
Reusing temporary buffers with ArrayPool
Use `ArrayPool<T>` to rent and return temporary arrays, which reduces garbage collection pressure by reusing buffers instead of allocating new ones repeatedly.
#11about 2 minutes
Implementing high-performance I/O with System.IO.Pipelines
System.IO.Pipelines simplifies efficient stream processing by managing buffers from an `ArrayPool`, allowing you to work with data as it becomes available.
#12about 4 minutes
Case study: Parsing large files with pipelines
By replacing a library that loaded an entire file into memory with a pipeline-based parser, allocations were reduced from over 7.2 GB to 242 MB.
#13about 2 minutes
Making the business case for performance optimization
Translate performance gains like reduced allocations and increased throughput into monetary value, such as lower infrastructure costs, to get buy-in from stakeholders.
#14about 3 minutes
Summary of key principles for high-performance code
Always measure your code, focus on hot paths, avoid memory copies by using `Span<T>`, and consider `ArrayPool` and `Pipelines` for I/O-heavy scenarios.
#15about 4 minutes
Q&A: Span to array costs and using ValueTasks
The Q&A covers the cost of converting a span back to an array and discusses when to use `ValueTask` over `Task` to avoid allocations in synchronous completion paths.
Related jobs
Jobs that call for the skills explored in this talk.
Dennemeyer Group
Hesperange, Luxembourg
Intermediate
Senior
.NET
Structured Query Language (SQL)
Matching moments
01:32 MIN
Organizing a developer conference for 15,000 attendees
Cat Herding with Lions and Tigers - Christian Heilmann
04:57 MIN
Increasing the value of talk recordings post-event
Cat Herding with Lions and Tigers - Christian Heilmann
03:17 MIN
Selecting strategic partners and essential event tools
Cat Herding with Lions and Tigers - Christian Heilmann
04:49 MIN
Using content channels to build an event community
Cat Herding with Lions and Tigers - Christian Heilmann
03:34 MIN
The business case for sustainable high performance
Sustainable High Performance: Build It or Pay the Price
02:44 MIN
Rapid-fire thoughts on the future of work
What 2025 Taught Us: A Year-End Special with Hung Lee
04:57 MIN
Developing resilience by expanding your capacity for failure
What 2025 Taught Us: A Year-End Special with Hung Lee
03:38 MIN
Balancing the trade-off between efficiency and resilience
What 2025 Taught Us: A Year-End Special with Hung Lee
Featured Partners
Related Videos
C# Lowering - What is it and why should I care?
Steven Giesel
Things I learned while writing high-performance JavaScript applications
Michele Riva
5 features that help you get the most out of C# 10
Louëlla Creemers
WebAssembly: Disassembled
Stefan Schöberl
Modern C#: A Dive into the Community's Most Loved new Features.
Louëlla Creemers
Hacking C# from the inside - how to do anything in NET
Adam Furmanek
Trash Talk - Exploring the memory management in the JVM
Gerrit Grunwald
Tips, tricks and quirks in .NET
Paweł Łukaszuk
Related Articles
View all articles



From learning to earning
Jobs that call for the skills explored in this talk.



Copello Global
Stevenage, United Kingdom
£60K
C++
Scrum
Unit Testing
Agile Methodologies
+3

Brightbox Grp Ltd
Charing Cross, United Kingdom
Remote
£104-119K
ETL
Azure
Spark
+3


Cognizant
Zürich, Switzerland
Senior
JIRA
Scrum
Jenkins
.NET Core
Kubernetes
+1

Client Server
Newcastle upon Tyne, United Kingdom
£100-130K
Senior
Python
.NET Core

Arm Limited
Cambridge, United Kingdom
ARM
Perl
VHDL
Linux
Python
+2

Pixelcode Technologies Limited
Wellesbourne, United Kingdom
£104K
API
JMeter
Performance Testing
Continuous Integration