zoukankan      html  css  js  c++  java
  • 开源框架Autofac使用入门

    • 目录导航
    • 1.Autofac是什么
      •   1.1什么是DI和IOC
      •   1.2DI和IOC在项目中起到什么作用
    • 2.Autofac如何使用
      •   2.1下载
      •   2.2代码Demo
      •   2.3Demo分析
    • 3总结

    1.Autofac是什么

      说到Autofac,我们就要首先了解依赖注入(Dependency Injection,简称DI)1.1节介绍。DI不是什么技术,而是一种设计模式,是用来降低计算机程序之间的耦合的。在.net平台,有很多依赖注入工具,比较于其他的IOC框架,如Spring.NET,Unity,Castle等等所包含的,Autofac是一款较为轻量级的、性能优异的、支持xml配置的依赖注入工具。这也是为什么我选择先学习Autofac的原因。

      1.1依赖注入(DI)和控制反转(IOC)

      DI

        DI是一种软件设计模式,用来允许我们开发松耦合代码。DI是一种很好的方式去减少软件模块之间的紧耦合关心。DI帮助更好的去管理软件中的功能更新和复杂度。DI的目的是让代码可维护。
      依赖注入模式使用构造器对对象初始化并提供需要的依赖给对象,也就意味着允许你从类外部注入一个依赖项。

      IOC

        IOC控制反转模式是对DIP(依赖倒置原则)的一种实现。
      IOC指的是一种框架或运行时的编程风格,用来控制程序流程。
      IOC意味着我们可以改变常规的控制方式。它在DIP下得以实现。许多基于.net框架的软件开发都使用IOC。
      IOC更多的是一个通用术语,不仅仅局限于DI。

      以上文字摘入 http://www.cnblogs.com/sheng-jie/p/6512909.html——(什么是依赖注入(DI)和控制反转(IOC)-详解)【圣杰】

      不明白的同学可以去翻翻。

      1.2DI和IOC在项目中起到什么作用

      例如,假设你的客户端类需要使用一个服务类组件,那么你能做的就是让你的客户知道一类IService接口而不是服务类。这样,你就可以随时改变Service类的实现而不会中断已经部署的代码。

    2.Autofac如何使用

      2.1下载

        首先你必须获取AutoFac,这里你可以通过各种方式加载它,我这里还是通过VS中的NuGet来加载AutoFac,不论是哪种方式,最终的目的就是将 Autofac.dll,Autofac.Configuration.dll 这两个程序集引用到你的项目中。这样在你的项目中,如果想使用AutoFac,只需添加其命名空间引用即可~ 这里我用的是2.6版本的(PS:Autofac.Configuration.dll V4.1 已经没有ConfigurationSettingsReader 用法稍有改变,还没去研究)

      2.2代码Demo

        在控制台程序中,首先

        /// <summary>
        /// 定义一个Animal接口
        /// </summary>
        public interface IAnimal
        {
            void DogCall();
            void CatCall();
        }

        写一个类继承此接口

        public class Call: IAnimal
        {
            public void CatCall()
            {
                Console.WriteLine("喵喵喵");
            }
    
            public void DogCall()
            {
                Console.WriteLine("汪汪汪");
            }
        }

        然后该Autofac出场了

            static void Main(string[] args)
            {
            var builder = new ContainerBuilder();//创建一个IOC容器
            builder.RegisterType<Call>().As<IAnimal>();//通过AS可以让Call类中通过构造函数依赖注入类型相应的接口。
            //Build()方法生成一个对应的Container实例,这样,就可以通过Resolve解析到注册的类型实例。
            using (var container = builder.Build())
            {
              //当注册的类型在相应得到的容器中可以Resolve你的Call类中所有实例。
              var call = container.Resolve<IAnimal>();
              call.DogCall();
              call.CatCall();
            }
    
            Console.ReadLine();
    
          }

        结果

        

      2.3Demo分析

      //我们使用Autofac的步骤:
      //第一步,定义一个Container容器。
      //第二步,创建builder,并在builder中注册类型。
      //第三步,实例化容器。
      //第四步,在需要使用接口的地方,通过container来解析得到一个借口的实例。

      这里我们也明白了一点,类型是需要先进行注册,然后才能够通过Autofac进行获取。

    然后我们能知道在Autofac中,先通过ContainerBuilder进行类型注册,然后通过ContainerBuilder的Build方法来获取IContainer类型实例,后面则可以通过该IContainer实例来获取注册类型的实例对象。

      

      另外:在项目中,我们想将该类型选择通过文件配置进行读取。Autofac自带了一个Autofac.Configuration.dll 非常方便地对类型进行配置,避免了程序的重新编译。

    修改App.config:

    在<configuration>根节点下加上(PS:configSections在程序配置文件中只能放在最前,不然会报配置文件未能初始化错误)

      <configSections>
        <section name="autofac" type="Autofac.Configuration.SectionHandler, Autofac.Configuration"/>
      </configSections>
      <!--IOC为控制台项目名称-->
      <autofac defaultAssembly="IOC">
        <components>
          <component type="IOC.Call, IOC" service="IOC.IAnimal" />
        </components>
      </autofac>

    然后将RegisterType注册方法替换为通过配置文件的方式注册

    //builder.RegisterType<Call>().As<IAnimal>();//通过AS可以让Call类中通过构造函数依赖注入类型相应的接口。
                builder.RegisterModule(new ConfigurationSettingsReader("autofac"));

    在简单实例中,我们已经看到了一种注册方式,那就是泛型注册:

    builder.RegisterType<Class_1>();

    其中还有很多注册的方式:

    Lambda注册

        builder.Register(cc =>
        {
            var clas1 = new Class_1();
            while (clas1.Id.ToString().Contains("a"))
            {
                clas1.Id = Guid.NewGuid();
            }
            return clas1;
        });

    程序集批量注册

        //获取当前应用程序加载程序集(C/S应用中使用)
        var assembly = Assembly.GetExecutingAssembly();
        var builder = new ContainerBuilder();
        builder.RegisterAssemblyTypes(assembly); //注册所有程序集类定义的非静态类型

    Module注册

    在日常开发中,可能不同开发会负责不同的模块进行单独开发。在开发过程中,不同模块不同开发可能都有自己的类型需要注册到autofac中,但是如果每个人在注册时,都去修改一个指定地方的代码,这在进行代码合并时,是令人痛苦的。更好的方式是,每个开发不同的模块都有自己指定的类型注册区域,这样,在代码合并时,会减少很多代码冲突。

    builder.RegisterModule<ModuleA>();

    个人非常推荐使用Module,每个项目拥有自己的一个Module,这样的一个Module都有固定的未知,便于查找该项目中的注册及依赖关系。

    3.总结

    IoC/DI

        关于IoC与DI的概念,网上有很多相关的博客,大家可以稍微了解一下,对比一下。

        我个人的理解就是按照英文的中文翻译来理解的:

        IoC: Inversion of Control 控制反转,将控制权进行反转,将本由自身控制的对象初始化交由外部IoC容器进行初始化;

        DI: Dependency Injection 依赖注入,将对象依赖的其他对象,通过注入的方式进行初始化。

    Autofac的用法远不止这些,这里面提到的只是我用到的一些内容。

    Autofac官方网站:http://autofac.org/

    Autofac在Github上的开源项目:https://github.com/autofac/Autofac

    Autofac的学习资源:https://github.com/autofac/Autofac/wiki

  • 相关阅读:
    图像处理之基础---图像缩放中的一些 灰度插值算法
    多媒体开发之---h264 取流解码分析
    校验算法之二进制反码求和
    c++学习笔记之基础---类内声明函数后在类外定义的一种方法
    图像增强---中值滤波
    阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第4节 多态_19_使用多态的好处
    阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第4节 多态_18_多态中成员方法的使用特点
    阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第4节 多态_17_多态中成员变量的使用特点
    阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第4节 多态_16_多态的格式与使用
    阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第4节 多态_15_多态的概述
  • 原文地址:https://www.cnblogs.com/lychee/p/6600553.html
Copyright © 2011-2022 走看看