zoukankan      html  css  js  c++  java
  • .NET Core DI简单介绍

    依赖注入的基础

    我们都知道DI,,他是一种开发模式。他是将服务可被应用程序任何位置的代码使用,当某个代码组件(如一个类)需要引用某些外部代码(一个服务)时。都有两种选择

    1:直接在调用代码种创建服务组件的一个新实例。

    2:收到该服务的一个有效实例。

    比如一个操作是记录操作记录。那么看以下代码。业务逻辑和记录操作紧密耦合

                
    public void  Home()
            {
                var log=new Logger();
                log.Log("Waring");
             }

    如果该类移动到其他位置,那么必须也要移动所有引用和依赖,如果有数据库操作。那么使用的地方都要有数据库连接,

    如果解耦

     private readonly ILogger _logger;
    
            public HomeController(ILogger  logger)
            {
                _logger = logger;
            }
         public void  Home()
            {
                var log=new Logger();
                log.Log("Waring");
             }

    将其抽象为ILogger 接口,通过构造函数注入。

    当然如果过度使用依赖注入,那么会有这样。依赖的有其他的依赖。以此类推。

    可以使用DI框架。同时也叫IOC框架

    var logger=SomeFrameworkIoC.Resolve(typeof(ILogger));

    Service Locator模式

    松耦合调用外部依赖,并非只有依赖注入。还有Service Locator。它能够创建与指定抽象类型匹配的实例。DI和它的关键区别在于,DI要求相应地设计外围代码;构造方法与其他方法的签名可能会发生变化。而它保守。  可读性差一点。当庞大的现有代码库种重构依赖时,它是一个理想选择。

    如下:

    public void Perform()
    {
       var logger=HttpContext.RequestService.GetService<ILogger>();
      
    }

    这是RequestService对象在HTTP上下文中扮演了Service Locator角色。

    当然依赖注入的生命周期。大家想必都有所了解。我这里简单说一下

  • 相关阅读:
    程序员眼中的 SQL Server-执行计划教会我如何创建索引?
    SQL Server死锁排查
    详解Java中的clone方法 -- 原型模式
    sql-索引的作用(超详细)
    java.util.ConcurrentModificationException 解决办法
    SqlServer索引的原理与应用
    数据库性能优化三:程序操作优化
    数据库性能优化二:数据库表优化
    数据库性能优化一:数据库自身优化(大数据量)
    SQL索引一步到位
  • 原文地址:https://www.cnblogs.com/mtxcat/p/12749553.html
Copyright © 2011-2022 走看看