>  기사  >  백엔드 개발  >  PHP의 DI 종속성 주입에 대해 이야기하는 기사

PHP의 DI 종속성 주입에 대해 이야기하는 기사

青灯夜游
青灯夜游앞으로
2022-08-25 10:50:383512검색

DI 의존성 주입이란 무엇인가요? 다음 기사는 PHP의 DI 종속성 주입에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다. DI/의존성 주입이란 일반 용어로 현재 클래스를 운영하고 있지만 이 클래스의 일부 메서드나 기능은 이 클래스만으로는 완료할 수 없지만 다른 클래스의 도움을 받아 로 완료할 수 있다는 의미입니다. class

가장 직접적인 신호는 매개변수 데이터가 객체로 전달되는 경우입니다. 엄밀히 말하면 한 클래스를 다른 클래스에서 조작하려는 경우 두 클래스 사이에는 매개변수 전달 방법을 injection이라고 합니다. PHP의 DI 종속성 주입에 대해 이야기하는 기사이유는 다음과 같습니다. 의존성 주입이 나타나는 이유

종속성 주입을 사용하지 않을 때 php가 한 클래스에서 다른 클래스를 사용해야 할 때 다음 작업이 자주 수행됩니다

    예를 들어 에 있을 때 <code>adapter 클래스를 >container 클래스에서 사용해야 하는 경우 사용하기 전에 인스턴스화해야 합니다. 많은 수의 외부 클래스를 사용해야 하는 경우 가 발생합니다. >커플링이 너무 높으면 나중에 쉽게 유지 관리 문제가 발생할 수 있습니다. 이를 컨테이너라고 합니다. 결합도가 너무 높습니다
  • 依赖注入DI 其实本质上是指对类的依赖通过构造器完成 自动注入
  • 通俗来说,就是你当前操作一个类,但是这个类的某些方法或者功能不是单单只靠这个类就能完成的,而是要 借助另一个类 的才能完成的
  • 最直接的标志就是传参数据为对象的时候。严格来说,你想在一个类中操作另一个类,这两个类之间形成了相互依赖关系,传参的方式叫 注入

依赖注入出现的原因

  • 在未使用依赖注入的时候,php 需要在一个类中使用另一个类的时候,往往都会进行如下操作
  • 比如我在 container 类中需要用到 adapter 类,就需要在使用之前进行实例化
  • 如果需要用到大量的外部类,这就会造成了 耦合度太高,很容易造成后期的 维护困难
  • 通俗的来讲,也就是 container 脱离不了外部类去工作,这就叫 耦合度太高
<?php
class container
{
    private $adapter;

    public function __construct()
    {
        $this->adapter = new adapter();
    }
}

简单的依赖注入

  • 上面的代码耦合度太高,导致了 依赖注入 的出现,主要是为了 解耦合
  • 如下案例,我们只需要将所需要操作的类对象传入即可
  • 依赖注入 操作的参数是 对象,而不是普通参数,是不是有更好的理解了
  • 但是这样的简单依赖注入,会造成如果你依赖的类很多,你传参的时候会很长,容易混乱
<?php
class container
{
    private $adapter;

    public function __construct(adapter $adapter)
    {
        $this->adapter = $adapter;
    }
}

高阶的依赖注入

  • 为了解决上面 参数混乱 的问题,这时候,依赖注入进行了优化
    通过魔术方法,__get 去设置对象
  • 这时候,我们就可以解决依赖太多,参数混乱的问题了
<?php
class container
{
    public $instance = [];

    public function __set($name, $value)
    {
        $this->instance[$name] = $value;
    }
}

$container = new container();

$container->adapter = new adapter();
$container->autofelix = new autofelix();

依赖注入的应用

  • 我们先定义一个 容器类,主要用来向容器中 注入 你想要操作的类
  • 使用的时候,只需要传容器这一个 对象 即可
<?php
class container
{
    public $instance = [];

    public function __set($name, $value)
    {
        $this->instance[$name] = $value;
    }
}

class adapter
{
    public $name = '我是调度器';
}

$container = new container();
$container->adapter = new adapter();

class autofelix
{
    private $container;

    public function __construct(container $container)
    {
        $this->container = $container;
    }

    public function who($class)
    {
        return $this->container->instance[$class]->name;
    }
}

$autofelix = new autofelix($container);

$who = $autofelix->who('adapter');

var_dump($who); //我是调度器

依赖注入高阶优化

  • 在上面的应用中,我们 直接 将实例化后的对象注入容器中
  • 这样会导致,所有的对象还没有被使用就会被实例化一遍,造成 资源的损耗
  • 我们可以 传入闭包,这样对象就不会被实例化而注入,当你自己需要使用的时候,再去实例化,就可以减少 服务器资源的损耗
    <?php
    $container = new container();
    $container->adapter = new adapter();
    
    //高阶优化
    $container = new container();
    $container->adapter = function () {
        return new adapter();
    };
간단한 종속성 주입

위 코드의 결합도가 너무 높아 주로 종속성 주입이 등장합니다. 디커플링🎜🎜다음 경우에는 연산이 필요한 클래스 객체만 전달하면 됩니다🎜🎜종속성 주입 연산의 매개변수는 Object 입니다. , 그리고 이는 일반적인 매개변수가 아닙니다. 하지만 이러한 간단한 종속성 주입으로 인해 많은 클래스에 의존하게 되면 매개변수를 전달하는 데 시간이 매우 길고 confusion🎜🎜 rrreee🎜🎜고수준 종속성 주입🎜🎜🎜🎜위의 매개변수 혼동 문제를 해결하기 위해 이번에는 종속성 주입이 최적화되었습니다
매직 메소드 __get를 통해 객체를 설정합니다🎜🎜이때, 의존성이 너무 많아 매개변수가 혼동되는 문제를 해결할 수 있습니다🎜🎜rrreee🎜🎜의존성 주입 적용🎜🎜🎜 🎜먼저 컨테이너 클래스를 정의합니다. 주로 컨테이너에 작업하려는 클래스를 주입하는 데 사용됩니다. 이를 사용할 때는 객체만 전달하면 됩니다. 🎜🎜rrreee🎜🎜고수준 종속성 주입 최적화🎜🎜🎜🎜위 애플리케이션에서는 인스턴스화된 개체를 컨테이너에 <code>직접 주입합니다.🎜🎜이로 인해 모든 개체가 사용되기 전에 인스턴스화되어 리소스 손실이 발생합니다🎜🎜클로저를 전달하여 개체가 인스턴스화되어 주입되지 않도록 할 수 있습니다. 서버 리소스🎜🎜rrreee🎜권장 학습: "🎜PHP 비디오 튜토리얼🎜"🎜

위 내용은 PHP의 DI 종속성 주입에 대해 이야기하는 기사의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제