当前位置: 首页 > article >正文

.net core三种依赖注入方式,原生的依赖注入器,scrutor,autofac

在 .NET Core 中,依赖注入(DI)是一个核心特性,它允许你管理应用程序中对象的生命周期和依赖关系。默认情况下,.NET Core 提供了一个内置的 DI 容器,但你也可以选择扩展它,或者使用第三方 DI 框架,如 ScrutorAutofac。下面我将介绍这三种方式的优缺点,并帮助你了解它们各自的特点。

1. 原生 .NET Core 依赖注入容器

.NET Core 默认提供了一个轻量级的依赖注入容器,通常称为 Microsoft.Extensions.DependencyInjection。这是一个开箱即用的解决方案,适用于大多数简单和中等复杂度的应用程序。

主要特点
  • 内置支持:不需要安装任何额外的库,直接使用 ASP.NET Core 项目就可以。
  • 简单易用:依赖注入 API 非常简洁,适合基本的 DI 使用场景。
  • 支持基本生命周期:支持 TransientScoped 和 Singleton 三种生命周期管理方式。
  • 有限的功能:不支持一些高级特性,例如条件注册、自动注册、按约定扫描类等。
使用示例
public void ConfigureServices(IServiceCollection services) {     
    services.AddTransient<IServiceA, ServiceA>(); // Transient生命周期         
    services.AddScoped<IServiceB, ServiceB>(); // Scoped生命周期 
    services.AddSingleton<IServiceC, ServiceC>(); // Singleton生命周期 
}

优点

  • 集成度高:与 ASP.NET Core 等框架高度集成。
  • 性能:由于它是一个轻量级容器,所以性能较好。
  • 学习曲线低:不需要额外学习和配置,适合大多数常见场景。
缺点
  • 功能有限:不支持像自动扫描、按约定注册等高级功能,且 API 较为基础。
  • 扩展性较差:如果需要更多的高级特性,可能需要自己实现很多功能,或者引入第三方库。

2. 原生 .NET Core 依赖注入容器 + Scrutor

Scrutor 是一个开源库,用来扩展 .NET Core 内置的 DI 容器,提供自动注册、按约定扫描类、条件注册等功能。它使得在使用原生依赖注入容器的基础上,能够享受更多的自动化和灵活性。

主要特点
  • 自动扫描和注册:Scrutor 支持自动扫描程序集和按命名空间、类后缀等约定进行注册,减少了手动注册的工作量。
  • 灵活的服务注册:可以根据不同的条件动态地注册服务(例如,根据配置或环境来选择服务)。
  • 更丰富的功能:可以链式调用和自定义注册行为,例如,按类名后缀注册或为服务添加拦截器。
使用示例
public void ConfigureServices(IServiceCollection services) { 
    services.Scan(scan => scan .FromAssemblyOf<Startup>() // 扫描程序集 
    .AddClasses(classes => classes.InNamespaceOf<Startup>()) // 按照命名空间选择类 
    .AsImplementedInterfaces() // 注册为实现的接口 
    .WithTransientLifetime()); // 使用Transient生命周期 
}

优点
  • 自动化:自动注册类和接口,避免了冗长的手动注册过程,尤其适合大型项目。
  • 灵活性强:支持按约定、条件和规则进行注册,可以更高效地管理服务。
  • 可扩展性:为原生容器添加了很多功能,使得开发人员可以更灵活地配置依赖注入。
缺点
  • 引入额外的库:需要额外添加 Scrutor 库。
  • 可能对性能有小影响:自动扫描和注册会带来一些性能开销,尤其是在大型应用中。

3. 使用 Autofac

Autofac 是一个流行的第三方依赖注入框架,提供了比 .NET Core 内置容器更丰富的功能。它支持复杂的服务生命周期、条件注册、模块化注册等高级功能,是 .NET Core 开发中常用的第三方 DI 框架之一。

主要特点
  • 高级功能:如条件注入、属性注入、模块化注册、依赖关系解析的粒度更细等,适合更复杂的场景。
  • 扩展性和灵活性:提供丰富的扩展机制,可以按需求调整 DI 行为,例如通过 Module 来批量注册服务,或者实现自己的 IServiceProvider
  • 性能优化:对于大规模应用,Autofac 的性能和管理能力较好,能够提供更多的控制和优化。
使用示例
public void ConfigureServices(IServiceCollection services) { 
    var builder = new ContainerBuilder(); 
    // 注册服务 
    builder.RegisterType<ServiceA>().As<IServiceA>().InstancePerDependency(); // Transient生命周期 
    builder.RegisterType<ServiceB>().As<IServiceB>().SingleInstance(); // Singleton生命周期 
    
    // 将现有服务添加到 Autofac 容器中 
    builder.Populate(services);  

    // 构建容器并使用它 
    var container = builder.Build(); 
    return new AutofacServiceProvider(container); 
}
优点
  • 丰富的功能:支持条件注入、属性注入、动态服务生成、模块化注册等复杂场景。
  • 扩展性强:提供了许多自定义钩子和扩展点,可以非常灵活地定制 DI 行为。
  • 性能:对于复杂的应用,Autofac 提供了更好的性能优化和服务管理能力。
缺点
  • 学习曲线较陡:相比原生的依赖注入容器,Autofac 提供了更多的配置和扩展选项,可能需要更多时间来学习和掌握。
  • 额外依赖:需要引入第三方库(Autofac),增加项目的复杂度。

总结与对比

特性原生 .NET Core DI原生 DI + ScrutorAutofac
学习曲线中等
功能基本增强(自动扫描、按约定)强大(条件注入、模块化注册等)
性能最优略低优化良好,适用于复杂场景
扩展性较差中等非常强
易用性中等中等
适用场景小型/中型项目中型项目,服务较多时大型、复杂的应用
  • 原生 .NET Core DI 适用于小型应用和中型应用,尤其是在功能需求相对简单时。
  • 原生 DI + Scrutor 适合中型到大型应用,尤其是当需要自动扫描、按约定注册和灵活配置时。
  • Autofac 适合大型、复杂的应用,特别是需要更多自定义和灵活性的场景。

根据你的项目规模、需求复杂度和团队的经验,选择适合的依赖注入方式是很重要的。


http://www.kler.cn/a/469822.html

相关文章:

  • Bash Shell的操作环境
  • Kali系统(Debian 10.3) 遇到的问题
  • 【C++数据结构——查找】二叉排序树(头歌实践教学平台习题)【合集】
  • unity学习8:unity的基础操作 和对应shortcut
  • Mac软件介绍之录屏软件Filmage Screen
  • ECCV`24 | 首次解决文本到3D NeRFs分解问题!港中文等提出DreamDissector
  • cat命令详解
  • leecode1035.不相交的线
  • 低功耗视频监控/太阳能无线监控在水产渔业养殖场景中有哪些应用?
  • Python编程实例-机器学习中的Hinge Loss编程实现
  • 基于SpringBoot的音乐网站与分享平台
  • 无人船 | 图解推导三自由度USV的运动学和动力学建模
  • 搭建直播网站技术层面准备全流程
  • 《创业维艰》
  • 在C程序中实现类似Redis的SCAN机制的LevelDB大规模key分批扫描
  • 了解 C# 中的字体别名问题
  • [创业之路-238]:《从偶然到必然-华为研发投资与管理实践》-1-产品研发过程的质量控制绝对了结果的质量,产品研发的过程控制的质量等级决定了结果质量的等级
  • Echarts集成Vue2个人总结与反思
  • Excel 打印时-预览界面内容显示不全
  • 技术速递|探索 Microsoft.Extensions.VectorData 与 Qdrant 和 Azure AI 搜索的结合使用
  • 小程序组件 —— 27 组件案例 -推荐商品区域
  • 【ROS2】☆URDF语法
  • 【SOC 芯片设计 DFT 学习专栏 -- ATE 测试中 at-speed 测试】
  • SQL-leetcode-262. 行程和用户
  • Android Studio 下载安装教程(2024 更新版),附详细图文
  • (CICD)自动化构建打包、部署(Jenkins + maven+ gitlab+tomcat)