Snowberry.DependencyInjection
2.0.0
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Snowberry.DependencyInjection --version 2.0.0
NuGet\Install-Package Snowberry.DependencyInjection -Version 2.0.0
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="Snowberry.DependencyInjection" Version="2.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Snowberry.DependencyInjection --version 2.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Snowberry.DependencyInjection, 2.0.0"
#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 Snowberry.DependencyInjection as a Cake Addin #addin nuget:?package=Snowberry.DependencyInjection&version=2.0.0 // Install Snowberry.DependencyInjection as a Cake Tool #tool nuget:?package=Snowberry.DependencyInjection&version=2.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
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>(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();
Registered services can be overwritten
...
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>();
...
This behavior can be disabled by using the ServiceContainerOptions
and creating the ServiceContainer
like this
var serviceContainer = new ServiceContainer(ServiceContainerOptions.ReadOnly);
Scopes
var serviceContainer = new ServiceContainer();
serviceContainer.RegisterScoped<IScopedType, ScopedType>();
serviceContainer.RegisterTransient<ITransientType, TransientType>();
// The current scope in this case would be the container itself, means it will be disposed by the container.
_ = serviceContainer.GetService<IScopedType>();
_ = serviceContainer.GetService<ITransientType>();
using(var scope = serviceContainer.CreateScope())
{
// The instance was created for current scope, the instance will be disposed by the scope.
_ = scope.ServiceFactory.GetService<IScopedType>();
_ = scope.ServiceFactory.GetService<ITransientType>();
}
// Dispose container
serviceContainer.Dispose();
Preferred constructor
The PreferredConstructorAttribute
attribute can be used to explicitly prefer a constructor. The attribute should be used only once.
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 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. |
.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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.