关于.net-core:耦合以及相关解耦的思想

11次阅读

共计 2320 个字符,预计需要花费 6 分钟才能阅读完成。

耦合是如何产生的?

一个类,往往须要跟其余对象打交道,既包含获知其余对象的状态,也包含依赖其余对象的行为,而一旦这样的事件产生时,咱们便称该类 依赖 于另一个对象。只有两个对象之间存在一方依赖另一方的关系,那么咱们就称这两个对象之间存在 耦合

解除依赖的思维是如何产生的?

(1)原始社会里,没有社会分工。须要斧子的人 (调用者) 仅仅能本人去磨一把斧子 (被调用者)。相应的情景为: 软件程序里的调用者本人创立被调用者。
(2) 进入工业社会,工厂呈现。斧子不再由普通人结束,而在工厂里被生产进去,此时须要斧子的人 (调用者) 找到工厂,购买斧子,毋庸关怀斧子的制作过程。相应软件程序的简略工厂的设计模式。

(3)进入“按需分配”社会,须要斧子的人不须要找到工厂,坐在家里收回一个简略指令: 须要斧子。斧子就天然出现在他背后。依赖注入。

从(1)、(2)能够看出,不同点是解放了本人工作,不须要去磨这个斧子了,然而相同点就是这个主导者,还仍然是本人。就说你本人磨斧子还是本人去工厂里去取。这个次要调用者当事人还是本人。

从(2)(3)能够看出,相同点,咱们不须要去磨这个斧子了。不同点,就是主导者变了,斧子曾经不须要咱们去取了,而是咱们想要什么就去要什么。就是控制权曾经扭转了,他曾经不是咱们本人去管制的了。

解耦

即让每一个局部都互相独立,一个局部的扭转不会影响其余局部。

我的项目代码松耦合状态

常见的解耦形式

  • DI(Dependency Injection),对依赖的解耦。
  • aop(Aspect Oriented Programming),对关注切面关注点业务逻辑的解耦。
  • Dto(Data Transfer Object),对模型的解耦。
  • ddd 畛域驱动设计,对畛域业务模块的解耦。

相干基本概念

类和对象

类:类是一个动态的概念,类自身不携带任何数据。当没有为类创立任何对象时,类自身不存在于内存空间中。
对象 new 实例化的过程:申明援用;
应用 new 关键字创立类的对象并对其初始化;(分配内存空间)将援用指向类的对象。

管制反转 IoC(Inversion of Control)

举例场景:
比方下面的例子(3)(工厂伐木),从本人须要去工厂买个斧子,而后咱们拿着斧子去上山伐木,变成甲方会给咱们提供斧子,咱们只须要在家里筹备好去就行了,这个时候,咱们对斧头这个控制权,曾经从咱们本人轻轻转化到调用者甲方身上了。这就是管制反转的思维。

比方你把程序里的一个写死的变量改成从配置文件里读取也是一种管制反转(由程序控制反转为由框架管制),你把这个配置改成用户 UI 界面的一个输出文本框由用户输出也是一种管制反转(由框架管制反转为由用户本人管制)。这些都用了管制反转思维。

什么是管制反转 IoC(Inversion of Control)?

是一种设计准则,最早由 Martin Fowler 提出,因为其实践提出工夫和成熟工夫绝对较晚,所以并没有被蕴含在 GoF 的《设计模式》中。
对依赖的管制,从本人,转到本人的调用者上。

依赖注入 DI(Dependency Injection)

依赖注入实现了 new(做了 new 实例化这个动作),不是为了省一个 new!

依赖注入实现 IoC 的其中一种设计办法。依赖的对象注入到调用者,你不应该本人创立它,而是应该通过构造函数,由你的调用者给你——容器。

举例场景——自动售货机

容器是一个自动售货机,组件是放在外面的在售商品,服务是商品的发售名称。

把商品(我的项目里的具体对象)放入自动售货机(容器)上架的过程叫注册;

注册的时候会给商品贴上标签,标注该商品的名称,这个名称就叫服务;

咱们还能够标注这个商品的适用人群和过期工夫等(生命周期作用域);

把这个包装后的商品放入自动售货机后,它就变成了在售商品(组件)。

当有顾客须要某个商品时,他只有对着售货机报一个商品名(服务名),自动售货机找到对应商品,抛出给客户,这个抛给你的过程,就叫做注入你;

而且这个售货机比拟智能,抛出前还能够先判断商品是不是过期了,该不该抛给你。

依赖注入的步骤
  • 注册,创立映射关系

蕴含三种生命周期:AddTransient,每次注入或申请时都会创立转瞬即逝的服务;AddScoped,是按范畴创立的, 在 Web 应用程序中, 每个 Web 申请都会创立一个新的独立服务范畴;其中 AddTransient 和 AddScoped 每次注册的服务都会在被应用一次之后,被 GC 销毁掉。AddSingleton,每个 DI 容器创立一个单例服务, 这通常意味着它们在每个应用程序只创立一次, 而后用于整个应用程序生命周期,会始终存在内存里。

  public void ConfigureServices(IServiceCollection services)
  {          
            // 注册
            services.AddSingleton<IHttpContextAccessor, HttpContextAccessor>();}
  • 创立,new 实例化
    public class ValuesController : ControllerBase
    {public IHttpContextAccessor HttpContextAccessor { get; set;}

        // 创立,这个时候去 new 实例
        public ValuesController(IHttpContextAccessor accessor)
        {_accessor = accessor;}
}
  • 调用 / 应用
        public ActionResult<IEnumerable<string>> Get()
        {
            // 调用
            var name = _accessor.HttpContext.User.Identity.Name;       
        }

援用 / 参考:https://www.bilibili.com/vide…

正文完
 0