1.什么是IOC容器
  定义:
    1.是一个可以把面向细节编程方式,转变为面向抽象编程方式的第三方容器(工厂模式差不多)

    2.可以用来自动化创建对象的容器(利用DI依赖注入和配置文件的手段来实现)

  遵循依赖倒置原则:
    高层不直接依赖底层的细节,而是通过抽象来依赖,也就是所谓的把面向细节编程变为面向抽象编程

  IOC控制反转:
    把高层对底层的依赖去掉,对象的控制权转移到第三方容器,让程序更具有扩展性

  DI依赖注入:
    实现IOC的一种手段,构造对象时,把依赖的对象自动创建并传入进去

  DI依赖注入的先后顺序:
    构造函数注入-->属性注入-->方法注入

2.为什么要用IOC容器
  面向细节编程:
    当我们面向细节编程的时候,如果细节变化了(扩展了),那么高层也需要改变,程序中往往底层的细节是容易改变的,这样会导致程序架构不稳定(往往我们的程序是不止一层的)

  面向抽象编程:
    当我们面向抽象编程的时候,如果细节变化了(扩展了),高层时不需要改变,这样阻止了程序升级时的水波效应,使程序架构更加稳定

  例如(随便举例子):

    手机类如下:

public class Iphone 
{
     public void Play()
     {
          Console.WriteLine("我在玩iphone");
      }
}

public class VIVO 
{
      public void Play()
      {
           Console.WriteLine("我在玩vivo");
      }
}

 

 

    学生类如下:

public class Student
{
    public void Play(IMobile iphone)
    {
         iphone.Play();
     }

}

    现在我们创建一个学生,并让学生玩iphone(面向细节)

//我们通过买一款iphone手机玩
public Unity_Test1()
{
    Student stu = new Student();
    Iphone iphone = new Iphone();
    stu.Play(iphone);
}

    到后面这个学生想玩vivo手机了,不想玩iphone,那么我们需要改低层的 Play(Iphone iphone)方法,应为它接受的是一个Iphone类型的参数,同时我们还需要改Unity_Test1类中的代码

 

    我们可以使用多态来解决此问题

      先定义一个接口,并让上面2款手机继承此手机接口,并把

public interface IMobile
{
     void Play();
}

 

      代码如下(多态:里氏替换原则):

Student stu = new Student();
IMobile iphone = new Iphone();
stu.Play(iphone);

 

      想玩vivo手机了,不想玩iphone,这下我们只需要更改  IMobile iphone = new Iphone();   此句话即可

public Unity_Test1()
{
     Student stu = new Student();
     IMobile iphone = new VIVO();
     stu.Play(iphone);
}

 

      注意:这里还是是依赖了细节(IMobile iphone = new VIVO();),并不满足依赖倒置原则(面向抽象,而不是面向细节)

 

3.如何实现依赖倒置原则

  问题:

    不依赖细节,那么我们如何创建对象呢?

  

  解决:

    把创建对象的事情交给第三方去实现