Soenneker.Reflection.Cache 3.0.245

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Soenneker.Reflection.Cache --version 3.0.245                
NuGet\Install-Package Soenneker.Reflection.Cache -Version 3.0.245                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Soenneker.Reflection.Cache" Version="3.0.245" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Soenneker.Reflection.Cache --version 3.0.245                
#r "nuget: Soenneker.Reflection.Cache, 3.0.245"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Soenneker.Reflection.Cache as a Cake Addin
#addin nuget:?package=Soenneker.Reflection.Cache&version=3.0.245

// Install Soenneker.Reflection.Cache as a Cake Tool
#tool nuget:?package=Soenneker.Reflection.Cache&version=3.0.245                

alternate text is missing from this package README image alternate text is missing from this package README image alternate text is missing from this package README image

alternate text is missing from this package README image Soenneker.Reflection.Cache

The fastest .NET Reflection cache

Why?

System.Reflection is slow. If you need to call Reflection code repeatedly, this library can drastically speed up subsequent calls. It's thread-safe and supports concurrency.

Installation

dotnet add package Soenneker.Reflection.Cache

This cache can either be added to DI like so:

public void ConfigureServices(IServiceCollection services)
{
    services.AddReflectionCacheAsSingleton(); // or AddReflectionCacheAsScoped()
}

and you could access it like:

public class MyService
{
    private readonly IReflectionCache _cache;

    public MyService(IReflectionCache cache)
    {
        _cache = cache;
    }
}

or you can instantiate it manually:

var cache = new ReflectionCache(threadSafe: true); // can be disabled for extra speed

Usage

var type1 = Type.GetType("System.String"); // <-- regular Reflection
var type2 = cache.GetType("System.String"); // <-- cached Reflection
bool areEqual = type1 == type2; // true

Keep in mind:

cache.GetType("System.String"); // <-- as slow as regular Reflection
cache.GetType("System.String"); // <-- very fast because the first call was cached

⚠️ Important ⚠️

Be mindful of the "cache chain". Use the Cached methods and types until you need to get the final Reflection type you need from the cache.

There are two methods for most operations like this:

Type typeofString = cache.GetType("System.String"); // <-- caches, stops the cache chain
CachedType type = cache.GetCachedType("System.String"); // <-- caches, continues the cache chain
Scenario: Retrieving parameters from a method

✅ Good:

CachedType cachedType = cache.GetCachedType("System.String");
CachedMethod cachedMethodInfo = cachedType.GetCachedMethod("Intern");
ParameterInfo?[] parameters = cachedMethodInfo.GetParameters(); // < -- parameters are now cached

❌ Bad:

CachedType cachedType = cache.GetCachedType("System.String");
MethodInfo methodInfo = cachedType.GetMethod("Intern"); // <-- uh oh, a non-cached Reflection type
ParameterInfo?[] parameters = methodInfo.GetParameters(); // <-- not cached, repeat calls are slow

Tips

  • Almost all of the Cached methods (e.g. GetCachedParameters() vs GetParameters() are faster due to the final preparation needed to match the System.Reflection methods.
  • Work with the Cached objects instead of Reflection objects if possible. They're faster to retrieve and allow for more efficient downstream chaining.
  • Thread safety can be disabled for more speed. It's enabled by default.
  • Consider if caching is even necessary for your use case. If you're only calling Reflection once, it may not be worth it.
  • Caching isn't free. Be thoughtful of your memory footprint and where/when you dispose of the cache.

Notes

  • A cache removal mechanism is needing to be built yet.
  • Many Reflection functionalities are not yet implemented, and could benefit from caching.
  • If you see something that could be improved (performance or allocation), please open an issue or PR.

Benchmarks (.NET 9.0)

GetType() 5,772% faster

Method Mean Error StdDev Ratio RatioSD
GetType_string_NoCache 1,022.30 ns 9.462 ns 8.851 ns baseline
GetType_string_Cache 17.52 ns 0.303 ns 0.283 ns 58.38x faster 1.12x
GetType_string_threadSafe_Cache 24.73 ns 0.139 ns 0.116 ns 41.29x faster 0.33x
GetCachedType_type_Cache 12.21 ns 0.234 ns 0.218 ns 83.76x faster 1.74x
GetCachedType_type_ThreadSafe_Cache 19.01 ns 0.067 ns 0.052 ns 53.73x faster 0.47x

GetMethods() 24,842% faster

Method Mean Error StdDev Ratio RatioSD
GetMethods_NoCache 256.526 ns 1.4587 ns 1.2180 ns baseline
GetMethods_Cache 1.030 ns 0.0412 ns 0.0385 ns 249.428x faster 10.30x

GetMethod() 37% faster

Method Mean Error StdDev Ratio RatioSD
GetMethod_NoCache 23.06 ns 0.234 ns 0.208 ns baseline
GetMethod_Cache 16.77 ns 0.079 ns 0.070 ns 1.37x faster 0.01x

GetMembers() 83,924% faster

Method Mean Error StdDev Ratio RatioSD
GetMembers_NoCache 550.2334 ns 4.1411 ns 3.8736 ns baseline
GetMembers_Cache 0.6579 ns 0.0515 ns 0.0481 ns 840.247x faster 58.17x
GetMembers_ThreadSafe_Cache 0.7273 ns 0.0307 ns 0.0287 ns 757.728x faster 31.76x

GetMember() 1,043% faster

Method Mean Error StdDev Ratio RatioSD
GetMember_NoCache 136.57 ns 1.353 ns 1.266 ns baseline
GetMember_Cache 11.95 ns 0.091 ns 0.081 ns 11.43x faster 0.12x

GetProperties() 8,960% faster

Method Mean Error StdDev Ratio RatioSD
GetProperties_NoCache 58.5363 ns 0.3463 ns 0.3070 ns baseline
GetProperties_Cache 0.6502 ns 0.0370 ns 0.0328 ns 90.25x faster 4.59x
GetProperties_ThreadSafe_Cache 0.7169 ns 0.0129 ns 0.0108 ns 81.72x faster 1.36x

GetProperty() 57% faster

Method Mean Error StdDev Ratio RatioSD
GetProperty_NoCache 25.61 ns 0.382 ns 0.357 ns baseline
GetProperty_Cache 16.23 ns 0.074 ns 0.062 ns 1.57x faster 0.01x

GetFields() 419% faster

Method Mean Error StdDev Ratio RatioSD
GetFields_NoCache 48.941 ns 0.9092 ns 0.8505 ns baseline
GetFields_Cache 1.141 ns 0.0512 ns 0.0479 ns 42.95x faster 1.32x
GetFields_ThreadSafe_Cache 1.178 ns 0.0144 ns 0.0128 ns 41.56x faster 0.79x

GetInterfaces() 1,439% faster

Method Mean Error StdDev Ratio RatioSD
GetInterfaces_NoCache 13.1880 ns 0.1197 ns 0.0999 ns baseline
GetInterfaces_Cache 0.8649 ns 0.0469 ns 0.0439 ns 15.39x faster 0.58x

GetInterface() 144% faster

Method Mean Error StdDev Ratio RatioSD
GetInterface_NoCache 32.84 ns 0.411 ns 0.364 ns baseline
GetInterface_Cache 13.47 ns 0.227 ns 0.212 ns 2.44x faster 0.05x

GetConstructors() 4,054% faster

Method Mean Error StdDev Ratio RatioSD
GetConstructors_NoCache 38.4477 ns 0.2020 ns 0.1687 ns baseline
GetConstructors_Cache 0.9280 ns 0.0109 ns 0.0102 ns 41.54x faster 0.36x
GetConstructors_ThreadSafe_Cache 1.0120 ns 0.0689 ns 0.0645 ns 38.39x faster 2.42x

GetConstructor() 601% faster

Method Mean Error StdDev Ratio RatioSD
GetConstructor_NoCache 18.16 ns 0.298 ns 0.278 ns baseline
GetConstructor_NoCache_Parameters 127.18 ns 1.592 ns 1.489 ns 7.01x slower 0.16x
GetConstructor_Cache 10.36 ns 0.057 ns 0.048 ns 1.76x faster 0.03x
GetConstructor_Cache_Parameters 21.12 ns 0.366 ns 0.342 ns 1.16x slower 0.02x

Activator.CreateInstance(params) vs cachedConstructor.CreateInstance(params) 242% faster

Method Mean Error StdDev Ratio RatioSD
Activator_Create_with_parameters 325.58 ns 1.713 ns 1.431 ns baseline
Cache_CreateInstance_with_parameters 95.61 ns 1.943 ns 1.908 ns 3.42x faster 0.07x

GetCustomAttributes() 1,658% faster

Method Mean Error StdDev Ratio RatioSD
GetAttributes_NoCache 2,560.76 ns 6.740 ns 6.305 ns baseline
GetAttributes_Cache 15.35 ns 0.287 ns 0.268 ns 166.858x faster 2.97x

GetGenericTypeDefinition() 499% faster

Method Mean Error StdDev Ratio RatioSD
GetGenericTypeDefinition_NoCache 1.8759 ns 0.0481 ns 0.0450 ns baseline
GetGenericTypeDefinition_Cache 0.3159 ns 0.0313 ns 0.0293 ns 5.99x faster 0.58x

IsAssignableFrom() 51% faster

Method Mean Error StdDev Ratio RatioSD
IsAssignableFrom_NoCache 9.355 ns 0.1357 ns 0.1270 ns baseline
IsAssignableFrom_Cache 6.198 ns 0.0794 ns 0.0742 ns 1.51x faster 0.04x

MakeGenericType() 1,485% faster

Method Mean Error StdDev Ratio RatioSD
MakeGenericType_NoCache 158.56 ns 0.900 ns 0.842 ns baseline
MakeGenericType_Cache 10.01 ns 0.216 ns 0.202 ns 15.85x faster 0.31x

GetElementType() 1,847% faster

Method Mean Error StdDev Ratio RatioSD
GetElementType_NoCache 4.9175 ns 0.0442 ns 0.0369 ns baseline
GetElementType_Cache 0.2585 ns 0.0204 ns 0.0191 ns 19.47x faster 1.06x

Properties on Type (e.g. typeof(string).IsNullable)

Method Mean Error StdDev Median
IsAbstract_NoCache 2.4277 ns 0.0319 ns 0.0299 ns 2.4152 ns
IsAbstract_Cache 0.0000 ns 0.0000 ns 0.0000 ns 0.0000 ns
IsInterface_NoCache 0.7720 ns 0.0219 ns 0.0194 ns 0.7662 ns
IsInterface_Cache 0.0045 ns 0.0076 ns 0.0071 ns 0.0000 ns
IsGenericType_NoCache 0.8707 ns 0.0281 ns 0.0262 ns 0.8732 ns
IsGenericType_Cache 0.2667 ns 0.0195 ns 0.0182 ns 0.2651 ns
IsEnum_NoCache 0.5322 ns 0.0242 ns 0.0227 ns 0.5291 ns
IsEnum_Cache 0.2612 ns 0.0251 ns 0.0235 ns 0.2526 ns
IsNullable_NoCache 1.4296 ns 0.0297 ns 0.0278 ns 1.4305 ns
IsNullable_Cache 0.2312 ns 0.0077 ns 0.0065 ns 0.2278 ns
IsByRef_NoCache 1.8439 ns 0.0332 ns 0.0310 ns 1.8410 ns
IsByRef_Cache 0.0012 ns 0.0025 ns 0.0022 ns 0.0000 ns
IsArray_NoCache 2.2914 ns 0.0484 ns 0.0452 ns 2.2652 ns
IsArray_Cache 0.0060 ns 0.0102 ns 0.0096 ns 0.0000 ns

Notes:

  • These benchmarks are built over iterations. The first operation is going to be as slow as the Reflection it sits in front of.
  • Many of these are based off of a test class TestType which is located in the test library.
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 is compatible. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Soenneker.Reflection.Cache:

Package Downloads
Soenneker.Cosmos.Serializer

A fast, lightweight JSON (de)serializer for Azure Cosmos DB

Soenneker.Utils.AutoBogus

The .NET Bogus autogenerator

Soenneker.Utils.String

A utility library for useful String operations

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
3.0.257 2,914 11/20/2024
3.0.256 3,629 11/19/2024
3.0.255 5,388 11/19/2024
3.0.254 53 11/19/2024
3.0.253 53 11/19/2024
3.0.252 56 11/19/2024
3.0.251 3,063 11/19/2024
3.0.250 54 11/19/2024
3.0.249 54 11/19/2024
3.0.248 57 11/19/2024
3.0.247 10,590 11/14/2024
3.0.246 3,682 11/14/2024
3.0.245 4,962 11/14/2024
3.0.244 72 11/14/2024
3.0.243 70 11/14/2024
3.0.242 72 11/14/2024
3.0.241 70 11/14/2024
3.0.240 62 11/14/2024
3.0.239 65 11/14/2024
3.0.238 67 11/14/2024
2.1.237 3,182 11/13/2024
2.1.236 9,113 11/12/2024
2.1.235 275 11/12/2024
2.1.234 67 11/12/2024
2.1.233 9,139 11/8/2024
2.1.232 3,245 11/8/2024
2.1.231 3,439 11/8/2024
2.1.230 13,399 10/31/2024
2.1.229 206 10/31/2024
2.1.228 6,314 10/29/2024
2.1.227 11,276 10/22/2024
2.1.226 7,226 10/22/2024
2.1.225 11,044 10/14/2024
2.1.224 5,430 10/11/2024
2.1.223 794 10/11/2024
2.1.222 7,142 10/8/2024
2.1.221 4,974 10/8/2024
2.1.220 78 10/8/2024
2.1.219 8,695 10/3/2024
2.1.218 8,702 10/2/2024
2.1.217 7,058 10/1/2024
2.1.216 6,912 9/29/2024
2.1.215 1,353 9/28/2024
2.1.214 6,129 9/27/2024
2.1.213 83 9/27/2024
2.1.212 245 9/27/2024
2.1.211 87 9/27/2024
2.1.210 91 9/27/2024
2.1.209 78 9/27/2024
2.1.208 82 9/27/2024
2.1.207 3,090 9/27/2024
2.1.206 8,279 9/26/2024
2.1.205 1,423 9/26/2024
2.1.204 7,160 9/25/2024
2.1.203 5,640 9/23/2024
2.1.202 4,859 9/23/2024
2.1.201 3,741 9/23/2024
2.1.200 85 9/23/2024
2.1.199 787 9/23/2024
2.1.198 80 9/23/2024
2.1.197 531 9/22/2024
2.1.196 89 9/22/2024
2.1.195 10,007 9/17/2024
2.1.194 569 9/17/2024
2.1.193 137 9/17/2024
2.1.192 83 9/17/2024
2.1.191 95 9/17/2024
2.1.190 87 9/17/2024
2.1.189 97 9/17/2024
2.1.188 24,933 9/11/2024
2.1.187 3,617 9/11/2024
2.1.186 9,012 9/10/2024
2.1.185 1,589 9/9/2024
2.1.184 3,120 9/9/2024
2.1.183 6,457 9/9/2024
2.1.182 8,295 9/6/2024
2.1.181 4,615 9/5/2024
2.1.180 2,068 9/5/2024
2.1.179 2,443 9/5/2024
2.1.178 92 9/5/2024
2.1.177 1,026 9/5/2024
2.1.176 96 9/5/2024
2.1.175 97 9/5/2024
2.1.174 7,985 9/4/2024
2.1.173 8,379 9/3/2024
2.1.172 3,013 9/3/2024
2.1.171 14,628 8/21/2024
2.1.170 1,539 8/20/2024
2.1.169 286 8/20/2024
2.1.168 112 8/20/2024
2.1.167 115 8/20/2024
2.1.166 2,532 8/20/2024
2.1.165 112 8/20/2024
2.1.164 104 8/20/2024
2.1.163 7,655 8/19/2024
2.1.162 8,091 8/13/2024
2.1.161 9,477 8/6/2024
2.1.160 6,509 8/1/2024
2.1.159 3,558 7/31/2024
2.1.158 6,538 7/25/2024
2.1.157 57 7/25/2024
2.1.156 2,164 7/24/2024
2.1.155 16,141 7/14/2024
2.1.154 7,620 7/10/2024
2.1.153 3,713 7/10/2024
2.1.151 1,624 7/9/2024
2.1.149 138 7/9/2024
2.1.148 6,105 7/9/2024
2.1.147 3,724 7/9/2024
2.1.146 90 7/9/2024
2.1.145 1,563 7/9/2024
2.1.144 91 7/9/2024
2.1.143 3,411 7/9/2024
2.1.141 597 7/8/2024
2.1.140 83 7/8/2024
2.1.139 85 7/8/2024
2.1.138 1,716 7/8/2024
2.1.137 8,381 7/7/2024
2.1.136 1,028 7/7/2024
2.1.135 12,270 7/3/2024
2.1.134 14,063 6/15/2024
2.1.133 10,519 6/1/2024
2.1.132 74 6/1/2024
2.1.131 608 6/1/2024
2.1.130 5,583 5/31/2024
2.1.129 3,254 5/29/2024
2.1.128 3,689 5/28/2024
2.1.127 2,373 5/27/2024
2.1.126 6,867 5/25/2024
2.1.125 1,850 5/25/2024
2.1.124 146 5/25/2024
2.1.123 102 5/25/2024
2.1.122 1,641 5/25/2024
2.1.121 108 5/25/2024
2.1.120 103 5/25/2024
2.1.119 108 5/25/2024
2.1.118 101 5/25/2024
2.1.117 18,111 5/23/2024
2.1.116 1,894 5/22/2024
2.1.115 1,489 5/22/2024
2.1.114 103 5/22/2024
2.1.113 105 5/22/2024
2.1.112 217 5/22/2024
2.1.111 3,749 5/22/2024
2.1.110 6,571 5/17/2024
2.1.109 6,853 5/14/2024
2.1.108 75 5/14/2024
2.1.107 14,057 4/29/2024
2.1.106 138 4/29/2024
2.1.105 3,767 4/28/2024
2.1.104 2,391 4/28/2024
2.1.103 102 4/28/2024
2.1.102 2,877 4/28/2024
2.1.101 103 4/28/2024
2.1.100 1,664 4/28/2024
2.1.99 106 4/28/2024
2.1.98 101 4/28/2024
2.1.97 103 4/28/2024
2.1.96 629 4/27/2024
2.1.95 103 4/27/2024
2.1.94 1,350 4/27/2024
2.1.93 12,709 4/12/2024
2.1.92 3,197 4/12/2024
2.1.91 110 4/12/2024
2.1.90 121 4/12/2024
2.1.89 150 4/12/2024
2.1.88 166 4/12/2024
2.1.87 113 4/12/2024
2.1.86 2,397 4/12/2024
2.1.85 126 4/12/2024
2.1.84 7,731 4/9/2024
2.1.83 3,774 4/1/2024
2.1.82 7,296 3/25/2024
2.1.81 4,153 3/19/2024
2.1.80 6,156 3/13/2024
2.1.79 115 3/13/2024
2.1.78 997 3/13/2024
2.1.77 113 3/13/2024
2.1.76 110 3/13/2024
2.1.75 2,874 3/12/2024
2.1.74 115 3/12/2024
2.1.73 7,869 3/8/2024
2.1.72 3,769 3/6/2024
2.1.71 2,043 3/4/2024
2.1.70 3,801 3/2/2024
2.1.69 1,601 3/2/2024
2.1.68 2,534 2/29/2024
2.1.67 4,742 2/25/2024
2.1.66 4,086 2/22/2024
2.1.65 2,139 2/21/2024
2.1.64 643 2/21/2024
2.1.63 1,363 2/21/2024
2.1.62 107 2/21/2024
2.1.61 121 2/21/2024
2.1.60 111 2/21/2024
2.1.59 115 2/21/2024
2.1.58 1,172 2/20/2024
2.1.57 3,197 2/20/2024
2.1.56 2,764 2/19/2024
2.1.55 117 2/19/2024
2.1.54 106 2/19/2024
2.1.53 122 2/18/2024
2.1.52 4,079 2/16/2024
2.1.51 117 2/16/2024
2.1.50 789 2/16/2024
2.1.49 1,274 2/16/2024
2.1.48 812 2/16/2024
2.1.47 1,524 2/16/2024
2.1.46 2,173 2/13/2024
2.1.45 2,169 2/13/2024
2.1.44 116 2/13/2024
2.1.43 117 2/13/2024
2.1.42 3,222 2/11/2024
2.1.41 2,303 2/11/2024
2.1.40 1,205 2/10/2024
2.1.39 116 2/10/2024
2.1.38 108 2/10/2024
2.1.37 150 2/9/2024
2.1.36 2,476 2/9/2024
2.1.35 1,545 2/9/2024
2.1.34 116 2/9/2024
2.1.33 1,451 2/8/2024
2.1.32 1,214 2/8/2024
2.1.31 1,162 2/8/2024
2.1.30 2,883 2/6/2024
2.1.29 1,118 2/6/2024
2.1.28 108 2/6/2024
2.1.27 2,263 2/6/2024
2.1.26 118 2/6/2024
2.1.25 167 2/5/2024
2.1.24 2,921 2/4/2024
2.1.23 111 2/4/2024
2.1.22 1,313 2/2/2024
2.1.21 94 2/1/2024
2.1.20 117 2/1/2024
2.1.19 137 2/1/2024
2.1.18 109 1/31/2024
2.1.17 101 1/31/2024
2.1.16 1,733 1/30/2024
2.1.15 4,058 1/28/2024
2.1.14 7,654 1/27/2024
2.1.13 856 1/26/2024
2.1.12 5,975 1/25/2024
2.1.11 106 1/25/2024
2.1.10 105 1/25/2024
2.1.9 109 1/25/2024
2.1.8 103 1/25/2024
2.1.7 2,281 1/23/2024
2.1.6 111 1/21/2024