浅谈ASP.NET Core中IOC与DI的理解和使用

说起IOC和DI,使用过ASP.NET Core的人对这两个概念一定不陌生,早前,自己也有尝试过去了解这两个东西,但是一直觉得有点很难去理解,总觉得对其还是模糊不清,所以,趁着今天有空,就去把两个概念捋清楚,并将学习过程的知识点记录下来。

 一、IOC和DI的理解

1.1 什么是IOC?

Ioc—Inversion of Control,即控制反转,其是一种设计思想,而不是一种技术。再没有使用IOC之前,我们一般是通过new来实例化,从而创建一个对象。但是我们使用IOC之后,创建这个对象的控制权将由内部转换到外部,那么这个过程便可以理解为控制反转。

1.2 什么是DI(依赖注入)?

全称为Dependency Injection,意思自身对象中的内置对象是通过注入的方式进行创建。形象的说,即由容器动态的将某个依赖关系注入到组件之中。

1.3 IOC和DI的联系?

IOC是一种设计思想,而DI是这种设计思想的一个实现。理解IOC和DI的关键是:“谁依赖谁,为什么需要依赖,谁注入谁,注入了什么”。

●谁依赖于谁:当然是应用程序依赖于IoC容器;
●为什么需要依赖:应用程序需要IoC容器来提供对象需要的外部资源;
●谁注入谁:很明显是IoC容器注入应用程序某个对象,应用程序依赖的对象;
●注入了什么:就是注入某个对象所需要的外部资源(包括对象、资源、常量数据)

 1.4 为啥需要反转?

为了在业务变化的时候尽量减少改动代码造成的问题。

1.5 使用DI的好处?

1)让程序之间松散耦合,减少依赖,有利于功能复用。

2)让程序整体结构更加灵活,有利于单元测试。

1.6 常见的IOC框架。

微软自带DI、Autofac、Unity

二、.NET Core自身DI使用

2.1.NET Core自身DI

ASP.NET Core本身已经集成了一个轻量级的IOC容器,开发者只需要定义好接口后,在Startup.cs的ConfigureServices方法里使用对应生命周期的绑定方法即可,常见方法如下

在start.up类中ConfigureServices方法对实例进行注册

这三个方法都是将我们实例注册进去,只不过是生命周期不一样。

AddSingleton:整个应用程序生命周期以内只创建一个实例,相当于一个静态类。

AddScoped:在同一个Scope内只初始化一个实例 ,可以理解为( 每一个request级别只创建一个实例,同一个http request会在一个 scope内)。

AddTransient:每一次都会创建一个新的实例。

 2.2 Demo应用

1)首先定义好一个IUserService接口,然后实现该接口

640?wx_fmt=png

640?wx_fmt=png

 2)在startup.cs类中ConfigureServices方法中添加下面代码

640?wx_fmt=png

3)通过构造函数来注入

640?wx_fmt=png

4)运行,查看结果

640?wx_fmt=png

 三、 采用Autofac替换IOC容器

Autofac是一款轻量级的IOC框架,目前和ASP.NET Core结合的非常好,官方网站http://autofac.org,源码下载地址https://github.com/autofac/Autofac。

1)在Nuget中引入两个:Autofac.Extras.DynamicProxy(Autofac的动态代理,它依赖Autofac,所以可以不用单独引入Autofac)、Autofac.Extensions.DependencyInjection(Autofac的扩展)

2)在startup.cs类中ConfigureServices方法中添加以下代码:(注意:把返回值类型改为IServiceProvider)

640?wx_fmt=png

3)同样也是通过构造函数进行注入

640?wx_fmt=png

4)运行,查看结果

640?wx_fmt=png

四、总结

本篇文章,主要是讲了IOC和DI的关系,以及通过微软自带的IOC框架和Autofac实现在ASP.NET Core中进行简单注入,其最大的优点就是实现了解耦的作用。同样,本篇文章也是为了记录自己学习的过程,后续有时间将会继续深入研究关于Autofac的内容。

好文参考:https://www.cnblogs.com/laozhang-is-phi/p/9541414.html(老张的哲学)

640?wx_fmt=png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315125.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #715 (Div. 1) C. Complete the MST 补图 + 思维 + 最小生成树

传送门 文章目录题意:思路题意: 给你一张nnn个点mmm个边的图,mmm条边是给定的,要求你给未给定的边赋值一个边权,使得所有边权异或和为000,求所有满足这种情况的图中最小生成树边权和最小的,输出…

一个通用数据库操作组件DBUtil(c#)、支持SqlServer、Oracle、Mysql、postgres、SQLITE

这是一个.net下操作数据库(结构数据库)的工具类,支持sqlserver、oracle、mysql、postgres、sqlite、access等常见数据库。注意:它并不是一个orm工具(常见的orm框架如:EF、Dapper等)。2.1 引入DBUtil依赖1. 首先打开vs(推荐vs2019)&#xff0c…

【NOI2012】迷失游乐园【概率期望】【换根dp】【基环树】

传送门 题意:给一棵nnn个点的带边权树或基环树,随机选一个点作为起点,每次随机走到一个相邻未走过的位置,直到无路可走。求期望路径长度。 n≤105n \leq 10^5n≤105,为基环树时环的大小不超过202020 先考虑树怎么做废话 先只考…

Educational Codeforces Round 37 (Rated for Div. 2) E. Connected Components? 暴力 + 补图的遍历

传送门 文章目录题意:思路:题意: n≤2e5,m≤2e5n\le2e5,m\le2e5n≤2e5,m≤2e5。 思路: 这是题是我上个题的一部分,算是个小知识点,暴力能过。 直接维护一个setsetset,让后遍历所有点&#xff…

初探System.Threading.Channels

。System.Threading.Channels是.Net Core基础类库中实现的一个多线程相关的库,专门处理数据流相关的操作,用来在生产者和订阅者之间传递数据(不知道可不可以理解为线程间传递数据,我把它类比成了Go语言中的Channel)&am…

【LOJ6033】棋盘游戏【二分图博弈】

传送门 显然是个二分图,设开始位置是左边,另一边是右边 那么先手是把左边挪到右边,后手是把右边挪到左边,不能挪的那方失败 结论:Alice必胜当且仅当开始位置不一定在最大匹配上 必要性: 如果开始位置不…

Codeforces Round #715 (Div. 1) B. Almost Sorted 找规律

传送门 文章目录题意:思路:题意: 思路: 找规律yydsyydsyyds。 一看没什么想法,所以打了个表,好家伙,不打不知道,一打不得了,下面是n6n6n6的符合要求的情况: …

SQL Server之索引解析(二)

、堆表堆表通过IAM连接一起,查询时全表扫描。1、1 非聚集索引结构叶子节点数据结构:行数据结构Rid(8字节)中间节点数据结构: (非聚集非唯一索引)行数据结构Page(4)2 Rid&…

【NOI2011】兔兔与蛋蛋的游戏【二分图博弈】

传送门 结论 不会有同一个棋子移动两次 反证法,对于第一个移动第二次的棋子 设两次移动之间(含)的移动的棋子为A1,A2,A3,……,AnA_1,A_2,A_3,……,A_nA1​,A2​,A3​,……,An​(指棋子本身而非位置) 因…

CF1528C dfs序+set维护

传送门 文章目录题意:思路:题意: 给你两棵有nnn个节点的树,我门记第一棵为aaa,第二棵为bbb,现在你有一个nnn个点都孤立的点集,两个点u,vu,vu,v可以连边当且仅当这两个点在aaa树中一个是另一个的…

纠正一个错误,分布式系统关注点第17篇

这里是Z哥的个人公众号每周五早8点 按时送达当然了,也会时不时加个餐~我的第「78」篇原创敬上今天来加个餐,紧急纠正一个错误。先和大家说一声抱歉:D昨晚睡觉前,惯例打开「订阅号助手」回复一些留言。有一位小伙伴提了…

【NOI2016】国王饮水记【贪心】【斜率优化】【决策单调性】

传送门 首先比h1h_1h1​小的肯定没用&#xff0c;直接无视 然后考虑合并的顺序 ①在无限制的情况下&#xff0c;合并多个不如一个一个合并 a<b<ca<b<ca<b<c时&#xff0c;ab2c2>abc3{{ab \over 2}c\over 2}>{{abc}\over 3}22ab​c​>3abc​ ②先…

CF946D Timetable 背包dp + 思维转换

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n,m,k≤500n,m,k\le500n,m,k≤500 思路&#xff1a; 将其转换成背包的模型&#xff0c;就可以想出来一个很明显的dpdpdp状态&#xff1a;f[i][j]f[i][j]f[i][j]表示前iii行花费了jjj的最小代价&#xff0c;…

.NET开发框架(三)-高可用服务器端设计

我们对框架功能作了简述&#xff0c;演示视频请点击 这里查看 &#xff0c;本章节&#xff0c;我们专门讲解一下&#xff0c;如何在Window服务器下&#xff0c;设计高可用的框架。我们的框架设计采用的是Window版本的服务端设计&#xff1a;整体框架图如下&#xff0c;为什么我…

P1537 弹珠 背包可行性dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 疯狂水文章。 这个很明显是个背包&#xff0c;我们开一个布尔数组&#xff0c;之后枚举每组的个数&#xff0c;让后枚举1−61-61−6&#xff0c;再枚举容量kkk&#xff0c;注意顺序不能错了…

【NOI2012】骑行川藏【拉格朗日乘数法】【二分套二分】

传送门 拉格朗日乘数法裸题 限制 f({v})∑i1nkisi(vi−vi′)EUf(\{v\})\sum_{i1}^nk_is_i(v_i-v_i)E_Uf({v})i1∑n​ki​si​(vi​−vi′​)EU​ 求 g({v})∑i1nsivig(\{v\})\sum_{i1}^n\frac{s_i}{v_i}g({v})i1∑n​vi​si​​ 最小值 设 L(λ,{v})g({v})λ[f({v})−EU]∑…

.NET Core 3.0中的WinForms创建集中式拉取请求中心

Windows 窗体&#xff08;或简称 WinForms&#xff09;&#xff0c;多年来被用于开发具有丰富和交互式界面的基于 Windows 的强大应用程序。各类企业对这些桌面应用程序的投入量非常巨大&#xff0c;每月有大约 240 万开发人员使用 Visual Studio 创建桌面式应用。利用和扩展现…

CF296B dp\容斥

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n≤1e5n\le1e5n≤1e5 思路&#xff1a; 求方案数基本就是考虑dpdpdp了&#xff0c;看到nnn这么大可以考虑一下分情况讨论的dpdpdp状态。 设f[i][j]f[i][j]f[i][j]表示到了第iii个&#xff0c;状态为jjj的方…

min_25筛详解

扯淡 min_25筛是由min_25提出的求积性函数前缀和的亚线性算法&#xff0c;和一个叫“扩展埃氏筛”的东西有着微妙的关系。 至于是什么关系&#xff0c;我也不太清楚&#xff0c;反正有人说很像有人说就是一个东西&#xff08;雾&#xff09; 这段话并不是废话 约定 为了方…

asp.net core 自定义异常处理中间件

Intro在 asp.net core 中全局异常处理&#xff0c;有时候可能不能满足我们的需要&#xff0c;可能就需要自己自定义一个中间件处理了&#xff0c;最近遇到一个问题&#xff0c;有一些异常&#xff0c;不希望记录错误日志&#xff0c;目前主要是用户请求取消导致的 TaskCanceled…