- Frugal Cafe
- Posts
- FC68: Finding the perfect place to cache a string
FC68: Finding the perfect place to cache a string
data:image/s3,"s3://crabby-images/b123d/b123d42ad885f8b0908a81a2bcca0317db656fcf" alt=""
Continue with optimizing PerfView’s xml generation performance, finding this expensive allocation stack:
data:image/s3,"s3://crabby-images/9284a/9284a3fd208c0ce09345529bea95ad414136a197" alt=""
TraceEventStackSource.GetFrameName is responsible for 43% allocations, 495 mb in total. Here is the source code:
data:image/s3,"s3://crabby-images/3b34e/3b34e6feecdc080ce288092f8ff640f12d381132" alt=""
Notice the expensive string generated is only depending on a single object, a TraceProcess object. So TraceProcess class is the perfect place to cache the string. We just need to add a new property:
data:image/s3,"s3://crabby-images/e9099/e90992e5b26f8b796a4dfc3b7a2838b1751aee72" alt=""
The FrameName property is calculated on first use, and then reused.
This is an effective caching mechanism, both for CPU and memory allocation. But in certain scenarios, this would be a working set nightmare. Luckily, this should not affect PerfView because there are limited number of TraceProcess objects, so added memory usage is not an problem.