Unity(IoC)

一、什么是IoC?

     IoC(Inversion of Control,控制反转)又称“依赖注入”(Dependence Injection,DI)。

     控制反转就是创建对象的权利由开发人员控制,转为由容器来控制。

     依赖注入就是通过容器创建对象的,是通过在构造方法的参数,属性设置和接口等方式注入的。

     IoC的基本概念是:不创建对象,但是描述创建它们的方式。在代码中不直接与对象和服务连接,但在配置文件(或程序)中描述创建关系,容器负责将它们联系起来。

二、什么是Unity?

     Unity是微软开发的一款轻量级、可扩展的IoC框架,可通过代码或者XML配置文件的形式来配置对象和对象直接的关系。

     在运行时直接调用容器即可获得我们需要的对象,以便建立松耦合的程序。

三、创建Unity Demo

     1.新建控制台项目UnityDemo

     2.右键UnityDemo项目,选择“管理NuGet程序包”,安装Unity程序包

     3.新建几个接口IPhone,IHeadphone,IMicrophone,IPower

public interface IHeadphone
    {

    }
 public interface IMicrophone
    {

    }
  public interface IPower
    {

    }
 public interface IPhone
    {
        /// <summary>
        /// 打电话
        /// </summary>
        void Call();

        IMicrophone iMicrophone { get; set; }
        IHeadphone iHeadphone { get; set; }
        IPower iPower { get; set; }
    }

    4.新建继承接口的类

 public class Headphone:IHeadphone
    {

    }
public class Microphone: IMicrophone
    {
    }

public class Power:IPower
    {
    }

 public class AndroidPhone : IPhone
    {
        public IHeadphone iHeadphone { get; set; }

        public IMicrophone iMicrophone { get; set; }


        public IPower iPower { get; set; }

        public AndroidPhone()
        {
            Console.WriteLine("{0}构造函数", this.GetType().Name);
        }

        public void Call()
        {
            Console.WriteLine("{0}打电话", this.GetType().Name); 
        }
    }

public class ApplePhone : IPhone
    {
        [Dependency] //属性注入
        public IHeadphone iHeadphone { get; set; }

        public IMicrophone iMicrophone { get; set; }

        public IPower iPower { get; set; }

        public ApplePhone()
        {
            Console.WriteLine("{0}构造函数", this.GetType().Name);
        }

        [InjectionConstructor] //构造函数注入
        public ApplePhone(IMicrophone iMicrophone)
        {
            this.iMicrophone = iMicrophone;

            Console.WriteLine("{0}带参数构造函数", this.GetType().Name);
        }

        public void Call()
        {
            Console.WriteLine("{0}打电话", this.GetType().Name);
        }

        [InjectionMethod]  //属性注入
        public void Init(IPower iPower)
        {
            this.iPower = iPower;
        }
    }

 

 四、编程方式注册对应关系

      Unity有三种注入方式:1.属性注入,使用[Dependency]特性  2.构造方法注入,使用[InjectionConstructor]特性(没有此特性,默认使用参数最多的构造方法)  3.方法注入,使用[InjectionMethod]特性

      1.创建一个UnityContainer对象

      2.通过UnityContainer对象的RegisterType方法来注册对象和对象之间的关系

      3.通过UnityContainer对象的Resolve方法来获取指定对象关联的对象

static void Main(string[] args)
        {
            try
            {
                Console.WriteLine("********************AndroidPhone**********************");
                {
                    IUnityContainer container = new UnityContainer();
                    container.RegisterType<IPhone, AndroidPhone>();
                    container.RegisterType<IHeadphone, Headphone>();
                    container.RegisterType<IMicrophone, Microphone>();
                    container.RegisterType<IPower, Power>();
                    IPhone phone = container.Resolve<IPhone>();
                    phone.Call();
                    //未注入   iHeadphone,iMicrophone,iPower 对象都为空             
                    Console.WriteLine("phone.iHeadphone == null? {0}", phone.iHeadphone == null);
                    Console.WriteLine("phone.iMicrophone == null? {0}", phone.iMicrophone == null);
                    Console.WriteLine("phone.iPower == null? {0}", phone.iPower == null);
                }

                Console.WriteLine("********************ApplePhone**********************");
                {
                    IUnityContainer container = new UnityContainer();
                    container.RegisterType<IPhone, ApplePhone>();
                    container.RegisterType<IHeadphone, Headphone>();
                    container.RegisterType<IMicrophone, Microphone>();
                    container.RegisterType<IPower, Power>();
                    IPhone phone = container.Resolve<IPhone>();
                    phone.Call();
                    //通过属性注入,构造函数注入,方法注入   iHeadphone,iMicrophone,iPower 对象不为空    
                    Console.WriteLine("phone.iHeadphone == null? {0}", phone.iHeadphone == null);
                    Console.WriteLine("phone.iMicrophone == null? {0}", phone.iMicrophone == null);
                    Console.WriteLine("phone.iPower == null? {0}", phone.iPower == null);
                }
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
            Console.ReadKey();
        }

  运行结果:

五、通过配置文件配置对应关系

     项目结构:

    配置文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="unity" type="Microsoft.Practices.Unity.Configuration.UnityConfigurationSection, Microsoft.Practices.Unity.Configuration" />
  </configSections>
  <unity>
    <!--定义别名-->
    <aliases>     
      <add alias="IPhone" type="UnityDemo.Interface.IPhone,UnityDemo" />
      <add alias="IHeadphone" type="UnityDemo.Interface.IHeadphone,UnityDemo" />
      <add alias="IMicrophone" type="UnityDemo.Interface.IMicrophone,UnityDemo" />
      <add alias="IPower" type="UnityDemo.Interface.IPower,UnityDemo" />

      <add alias="AndroidPhone" type="UnityDemo.Service.AndroidPhone,UnityDemo" />
      <add alias="ApplePhone" type="UnityDemo.Service.ApplePhone,UnityDemo" />
      <add alias="Headphone" type="UnityDemo.Service.Headphone,UnityDemo" />
      <add alias="Microphone" type="UnityDemo.Service.Microphone,UnityDemo" />
      <add alias="Power" type="UnityDemo.Service.Power,UnityDemo" />
    </aliases>
    <!--容器-->
    <container name="MyContainer">
      <!--映射关系-->
      <register type="IPhone" mapTo="ApplePhone"/>
      <register type="IHeadphone" mapTo="Headphone"/>
      <register type="IMicrophone" mapTo="Microphone"/>
      <register type="IPower" mapTo="Power"/>
    </container>
  </unity>
</configuration>

   调用代码:

public static void ContainerConfiguration()
        {
            IUnityContainer container = new UnityContainer();
            ExeConfigurationFileMap fileMap = new ExeConfigurationFileMap { ExeConfigFilename ="Unity.config"};
            Configuration configuration =  ConfigurationManager.OpenMappedExeConfiguration(fileMap, ConfigurationUserLevel.None);
            UnityConfigurationSection section =(UnityConfigurationSection)configuration.GetSection("unity");
            container.LoadConfiguration(section, "MyContainer");
            IPhone phone = container.Resolve<IPhone>();
            phone.Call();
            //通过属性注入,构造函数注入,方法注入   iHeadphone,iMicrophone,iPower 对象不为空    
            Console.WriteLine("phone.iHeadphone == null? {0}", phone.iHeadphone == null);
            Console.WriteLine("phone.iMicrophone == null? {0}", phone.iMicrophone == null);
            Console.WriteLine("phone.iPower == null? {0}", phone.iPower == null);
        }

 

转载于:https://www.cnblogs.com/marshhu/p/6811551.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前言 unity的框架,除了各大公司自己内部使用的,开源并好用的实际并不是很多,我会慢慢挖掘,依次写出自己的一点见解,错误的地方,望各路大神指正。 一、基本概念 控制反转(Inversion of Control,英文缩写为IOC),我的理解就是,原本A类要获取B类的对象,需要你在A类中自己New一个对象,那么是由A来获取并控制B的对象,IOC就是把对象获取的这个过程交给容器和依赖注入来处理,A类并不知道B的对象是哪里来的,对B对象的控制,由自己变成了其他类,官方一点的概念可以百度,这个还是蛮多的。 二、StrangeIOC基础类型 实际要理解一个框架的类型,还是要自己看源码,这里我只说一下几个重要类型的作用,这个看源码的时候有个印象,也方便理解,而且说这部分的帖子也很多,我就不再赘述了。 1.Context 上下文组件定义程序边界,也就是可以把一个程序定义成多上下文,让代码更加模块化 它提供了程序入口,也算是框架中耦合度最高的地方 2.Binder和Binding 这两个类是这个框架最重要的组成部分 Binding存储了对象的绑定关系,而Binder存储了Binding的对象 3.View和Mediator MVCS中的View层,View只用于显示,也就是View只负责管理UI,Mediator负责界面逻辑,事件响应等 4.Model MVCS中的Model层,负责数据部分 5.Command MVCS中的Control层,负责执行逻辑代码 6.Service MVCS中的Service层,负责与第三方交互,这个Service我理解的,并不是一定指代服务器,也可以是其他的软件,什么都可以,它就是我们程序对外的接口 7.Dispatcher 派发器是框架内通信主线的其中一种,用来派发消息,触发命令,从而进一步解耦 8.Signal 信号是框架内另外一种通信主线,它采用强类型,来绑定信号和命令之间的关系,实现消息响应的触发 9.ReflectionBinder 反射部分,通过binding来获取类的信息,存储在ReflectedClass中 10.injector 注入器,通过反射获取的信息,来实例化请求的对象 --------------------- 作者:蓝天小僧 来源:CSDN 原文:https://blog.csdn.net/zcaixzy5211314/article/details/80876228 版权声明:本文为博主原创文章,转载请附上博文链接!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值