ASP.NET CORE 依赖注入的三种方式,分别是什么,使用场景

依赖注入 (Dependency Injection,简称 DI)中,通常有三种常见的服务生命周期模式,用于控制服务实例的创建和管理。这些模式分别是:TransientScopedSingleton 。这三种模式在 ASP.NET Core 中非常重要,因为它们决定了依赖项在应用程序中的生命周期。以下是这三种模式的详细解释:

1. Transient(瞬态)

  • 生命周期: 每次请求都会创建一个新的服务实例。
  • 适用场景: 短生命周期、无状态的服务。每次注入时需要一个新的对象实例。
  • 注册方式: services.AddTransient<TService, TImplementation>();

特点:

  • 当你需要服务在每个请求中创建一个新实例时,使用 Transient
  • 不共享实例,因此每次注入都会得到一个新的对象。
  • 适合那些不保存状态的服务,比如某些业务逻辑操作、数据库查询等。

示例:

复制代码

csharpCopy Code

public void ConfigureServices(IServiceCollection services) { services.AddTransient<IMyService, MyService>(); }

使用场景:

  • 无状态的服务或具有短生命周期的服务(例如,服务在每次调用时进行独立处理,并不需要维护任何持久化数据)。

2. Scoped(作用域)

  • 生命周期: 在每个请求或作用域内创建一个服务实例,并且在同一个请求或作用域中共享该实例。
  • 适用场景: 适用于需要在同一请求中共享实例的服务。典型场景是数据库上下文(DbContext)等。
  • 注册方式: services.AddScoped<TService, TImplementation>();

特点:

  • 在同一个 HTTP 请求或作用域中,共享同一个服务实例。
  • 适用于服务依赖于请求上下文或作用域(如数据库事务或用户会话数据)的场景。
  • 跨请求时会重新创建实例,但在同一个请求内不会重复创建实例。

示例:

复制代码

csharpCopy Code

public void ConfigureServices(IServiceCollection services) { services.AddScoped<IMyService, MyService>(); }

使用场景:

  • 每个用户请求共享同一个实例,但不同的请求之间的实例是隔离的。
  • 适用于数据库连接、用户请求处理等场景。

3. Singleton(单例)

  • 生命周期: 在整个应用程序生命周期内只创建一个实例,所有请求共享同一个实例。
  • 适用场景: 对象实例创建开销较大,或者需要在整个应用程序中共享数据或服务的场景。
  • 注册方式: services.AddSingleton<TService, TImplementation>();

特点:

  • 在整个应用程序运行期间,服务只有一个实例。
  • 适合跨请求共享数据,或者服务的实例化成本较高且不需要频繁变化的情况。
  • Singleton 服务可能会在应用启动时就被创建,或者首次被请求时才会创建。

示例:

复制代码

csharpCopy Code

public void ConfigureServices(IServiceCollection services) { services.AddSingleton<IMyService, MyService>(); }

使用场景:

  • 适用于跨多个请求需要共享数据的服务,如缓存、配置管理、日志记录等。
  • 常用于应用启动时需要初始化的单例服务。

4. 总结比较

生命周期类型 服务实例的创建频率 生命周期说明 适用场景
Transient 每次请求时创建 每次依赖注入都会新建一个实例 无状态服务、轻量级服务
Scoped 在每个请求内共享 在一个请求的整个生命周期中使用同一个实例 数据库上下文、事务、用户请求上下文等
Singleton 整个应用程序生命周期内共享 在应用程序生命周期中共享同一个实例 配置管理、缓存、日志服务等

5. 使用场景举例

  • Transient:数据库查询服务、HTTP客户端服务。
  • ScopedDbContext(通常每个请求使用一个数据库上下文)、身份验证服务。
  • Singleton:应用配置、缓存、日志记录、缓存管理器。

通过合理选择服务生命周期模式,可以在保证应用性能的同时,更好地管理对象的状态和生命周期。

相关推荐
dishugj11 小时前
HANA 数据库的核心进程架构
数据库
Supersist11 小时前
【设计模式03】使用模版模式+责任链模式优化实战
后端·设计模式·代码规范
2301_7820404511 小时前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between
jvm·数据库·python
.柒宇.11 小时前
Redis主从复制集群搭建详解
数据库·redis·缓存·主从复制
Fox爱分享11 小时前
字节二面:10亿数据毫秒级查手机尾号后4位,答不出“异构索引”直接挂?
java·后端·面试
2301_8084143811 小时前
MySQL中的函数
数据库·mysql
折哥的程序人生 · 物流技术专研11 小时前
《Java面试85题图解版(二)》进阶深化上篇:并发编程 + JVM
java·开发语言·后端·面试
Mahir0811 小时前
MySQL 数据一致性的基石:三大日志( redo log/undo log/binlog)与两阶段提交(Prepare 阶段和Commit 阶段)深度解密
数据库·后端·mysql·面试
L0CK11 小时前
Redis 内存淘汰策略
后端
zhengzizhe12 小时前
ReBAC 与 Google Zanzibar:权限系统的未来
后端·架构