zoukankan      html  css  js  c++  java
  • PHP依赖注入原理与用法分析

    https://www.jb51.net/article/146025.htm

    本文实例讲述了PHP依赖注入原理与用法。分享给大家供大家参考,具体如下:

    引言

    依然是来自到喜啦的一道面试题,你知道什么是依赖注入吗?

    依赖注入(DI)的概念虽然听起来很深奥,但是如果你用过一些新兴的php框架的话,对于DI一定不陌生,因为它们多多少少都用到了依赖注入来处理类与类之间的依赖关系。

    php中传递依赖关系的三种方案

    其实要理解DI,首先要明白在php中如何传递依赖关系。

    第一种方案,也是最不可取的方案,就是在A类中直接用new关键词来创建一个B类,如下代码所示:

    <?php
    class A
    {
      public function __construct()
      {
        $b = new B();
      }
    }

    为什么这种方案不可取呢?因为这样的话,A与B就耦合在了一起,也就是说A类无法脱离B类工作。

    第二种方案就是在A类的方法中传入需要的B类,如下代码所示:

    <?php
    class A
    {
      public function __construct(B $b)
      {
      }
    }

    这种方法比第一种方案有了改进,A类不必与B类捆绑在一起,只要传入的类满足A类的需求,也可以是C类,也可以是D类等等。

    但是这种方案的弊端在于如果A类依赖的类较多,参数列表会很长,容易发生混乱。

    第三种方案是使用set方法传入,如下代码所示:

    这种方法比第一种方案有了改进,A类不必与B类捆绑在一起,只要传入的类满足A类的需求,也可以是C类,也可以是D类等等。
    
    但是这种方案的弊端在于如果A类依赖的类较多,参数列表会很长,容易发生混乱。
    
    第三种方案是使用set方法传入,如下代码所示:
    <?php
    class A
    {
      public function setB(B $b)
      {
        $this->b = $b;
      }
    }
    

      

    这种方案同样存在和第二种方案一样的弊端,当依赖的类增多时,我们需要些很多很多的set方法。

    这时我们在想如果有一个专门的类(或者说一个容器)可以帮我们管理这些依赖关系就好了。

    一个简单的依赖注入的例子

    如下代码来自twittee

    <?php
    class Container {
     private $s=array();
     function __set($k, $c) { $this->s[$k]=$c; }
     function __get($k) { return $this->s[$k]($this); }
    }
    

      有了container类之后我们可以怎样管理A与B之间的依赖关系呢,用代码说话吧:

    <?php
    class A
    {
      private $container;
      public function __construct(Container $container)
      {
        $this->container = $container;
      }
      public function doSomeThing()
      {
        //do something which needs class B
        $b = $this->container->getB();
        //to do
      }
    }

    再将B类注入到容器类中:

    $c = new Container();
    $c->setB(new B());

    还可以传入一个匿名函数,这样B类就不会在传入时就立即实例化,而是在真正调用时才完成实例化的工作:

    $c = new Container();
    $c->setB(function (){
      return new B();
    });
    

      

  • 相关阅读:
    自主学习1
    动手动脑10.28
    《程序员修炼之道》阅读笔记三
    《程序员修炼之道》阅读笔记
    11月20,21,22训练赛
    Rabbits(跳兔子)
    01背包变式(并查集+dp01背包)
    问题 I: 约会序列(两边枚举)
    问题 J: 直角三角形
    Cow Exhibition (01背包的负数处理)
  • 原文地址:https://www.cnblogs.com/yszr/p/10699223.html
Copyright © 2011-2022 走看看