Snowberry.DependencyInjection
5.1.1
dotnet add package Snowberry.DependencyInjection --version 5.1.1
NuGet\Install-Package Snowberry.DependencyInjection -Version 5.1.1
<PackageReference Include="Snowberry.DependencyInjection" Version="5.1.1" />
<PackageVersion Include="Snowberry.DependencyInjection" Version="5.1.1" />
<PackageReference Include="Snowberry.DependencyInjection" />
paket add Snowberry.DependencyInjection --version 5.1.1
#r "nuget: Snowberry.DependencyInjection, 5.1.1"
#:package Snowberry.DependencyInjection@5.1.1
#addin nuget:?package=Snowberry.DependencyInjection&version=5.1.1
#tool nuget:?package=Snowberry.DependencyInjection&version=5.1.1
A lightweight easy to use IoC container for .NET.
Usage
The ServiceContainer should be disposed when no longer in use.
var serviceContainer = new ServiceContainer();
// Provided instances won't be disposed by the container.
var providedSingletonInstance = new SomeType();
serviceContainer.RegisterSingleton<ISomeType>(instance: providedSingletonInstance);
// The instance created by the container will be disposed by the container.
serviceContainer.RegisterSingleton<ISomeOtherType, SomeOtherType>();
serviceContainer.RegisterTransient<ITransientType, TransientType>();
// Dispose container
serviceContainer.Dispose();
// Or
serviceContainer.DisposeAsync()
Existing registered services can be overwritten, if the ServiceContainer is not created with the ServiceContainerOptions.ReadOnly option.
var serviceContainer = new ServiceContainer(ServiceContainerOptions.Default & ~ServiceContainerOptions.ReadOnly);
serviceContainer.RegisterTransient<ITransientType, TransientType>();
// This makes the ITransientType service a singleton service with another implementation type.
// The container/scope will still dispose the previously created transient service instances.
serviceContainer.RegisterSingleton<ITransientType, NewTransientType>();
...
Scopes
var serviceContainer = new ServiceContainer();
serviceContainer.RegisterScoped<IScopedType, ScopedType>();
serviceContainer.RegisterTransient<ITransientType, TransientType>();
serviceContainer.RegisterTransient<ITestService, TestServiceKeyedA>("_KEY0_");
// The current scope in this case would be the container itself, means it will be disposed by the container.
_ = serviceContainer.GetRequiredService<IScopedType>();
_ = serviceContainer.GetRequiredService<ITransientType>();
_ = serviceContainer.GetRequiredKeyedService<ITestService>("_KEY0_");
using(var scope = serviceContainer.CreateScope())
{
// The instance was created for current scope, the instance will be disposed by the scope.
_ = scope.ServiceFactory.GetRequiredService<IScopedType>();
_ = scope.ServiceFactory.GetRequiredService<ITransientType>();
}
// Dispose container
serviceContainer.Dispose();
Open Generic Types
serviceContainer.Register(typeof(IOpenGenericService<>), typeof(OpenGenericService<>), serviceKey: null, lifetime: ServiceLifetime.Transient, singletonInstance: null);
Attributes
PreferredConstructorAttribute
The PreferredConstructorAttribute attribute can be used to explicitly prefer a constructor. The attribute should be used only once.
FromKeyedServicesAttribute
The FromKeyedServicesAttribute attribute can be used to explicitly use a service from a keyed service collection.
- The attribute can't be used multiple times.
- The attribute can only be used on properties and parameters and is inherited.
InjectAttribute
The InjectAttribute attribute can be used to explicitly inject a service into a property.
- The attribute can't be used multiple times.
- The attribute can only be used on properties and is inherited.
The attribute can also be combined with the FromKeyedServicesAttribute attribute.
[Inject]
[FromKeyedServices("_KEY1_")]
public ITestService? KeyedPropertyInjectTestService { get; set; }
Service lifetime
| Name | Description |
|---|---|
| Singleton | Specifies that a single instance of the service will be created. |
| Transient | Specifies that a new instance of the service will be created every time it is requested. |
| Scoped | Specifies that a new instance of the service will be created for each scope. |
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 is compatible. 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. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Snowberry.DependencyInjection.Abstractions (>= 5.1.1)
-
net10.0
- Snowberry.DependencyInjection.Abstractions (>= 5.1.1)
-
net8.0
- Snowberry.DependencyInjection.Abstractions (>= 5.1.1)
-
net9.0
- Snowberry.DependencyInjection.Abstractions (>= 5.1.1)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Snowberry.DependencyInjection:
| Package | Downloads |
|---|---|
|
Snowberry.Mediator.DependencyInjection
Extension for the main package to work with `Snowberry.DependencyInjection`. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | |
|---|---|---|---|
| 5.1.1 | 34 | 1/28/2026 | |
| 5.1.0 | 212 | 11/15/2025 | |
| 5.0.0.2 | 252 | 11/4/2025 | |
| 5.0.0.1 | 309 | 11/4/2025 | |
| 5.0.0 | 320 | 11/4/2025 | |
| 4.0.0 | 227 | 10/7/2025 | |
| 3.8.0 | 372 | 9/22/2025 | |
| 3.7.0 | 238 | 8/1/2025 | |
| 3.6.0 | 712 | 11/14/2024 | |
| 3.5.0 | 454 | 10/9/2024 | |
| 3.4.0 | 716 | 8/28/2024 | |
| 3.3.0 | 2,002 | 3/28/2024 | |
| 3.2.0 | 1,111 | 1/31/2024 | |
| 3.1.0 | 305 | 1/31/2024 | |
| 3.0.0 | 311 | 1/31/2024 | |
| 2.0.0 | 832 | 12/20/2023 | |
| 1.0.3 | 2,214 | 3/8/2023 |