依赖注入与哪些事情无关?

2022-10-07,,,

任何你使用的现代框架,都可能严重依赖于依赖注入。但是你知道依赖注入代表的真正含义吗?或者换一个更好的角度 - 你知道依赖注入不是什么吗?

 

依赖容器

虽然每个现代框架都附带依赖容器 — 一个用于构建对象的大盒子 — 但这并不能保证你会按照预期的方式使用依赖注入模式。

容器让依赖项更加容易注入到类中,但是它也可能被滥用。

服务定位器模式

一种滥用服务容器的方式是从容器中拉取对象,而不是注入到当前的上下文中。该模式称之为服务定位器模式,它与依赖注入相反。

class mycontroller
{
    public function indexaction()
    {
        $service = app(service::class);

        // …        
    }
}

  

服务定位器模式向容器请求特定的对象。这将导致服务从一个难以测试的点拉取,并且,对于外部而言这就像一个黑匣子:除非你查看全部相关代码,否则你将无法了解 mycontroller 所依赖的外部类型。

 

一些框架提倡这种用法,因为在项目开始的时候它将变得简单快捷。一旦在容器中注册了成百上千个类,使用服务定位器模式将会导致混乱。而使用依赖注入将解决该问题。

 

更多信息,可查看我写的这篇博客: 为什么服务定位器模式是反模式.

 

依赖共享

接下来是一些更积极的方面:以一种更好的方式使用容器。

当依赖注入被正确使用时,外部上下文 (在许多情况下为容器) 可以控制注入到类中的具体依赖项。 这意味着同一个对象可以被注入到其他几个上下文中,而不需要知道这些上下文是「单例」还是「依赖共享」。

 

虽然依赖共享是有用且强大的,但它并不是依赖注入的真正目的,而只是一个有益的副作用。

 

自动装配

最后,另一个有用的特性,同样不是依赖注入的内容:自动装配。

为了给予开发人员更多的灵活性,一些容器允许智能的、自动的确定类的定义。这意味着您不必手动描述应该如何构造每个类。这些容器将扫描您的代码,并通过查看类型提示和文档块来确定需要哪些依赖项。

 

这里发生了很多神奇的事情,但是自动装配对于应用程序的快速开发来说是一个非常有用的工具。

 

如果您现在还想重温一下什么是依赖注入的基础知识。你可以去阅读它这里.

 

更多学习内容请访问:

腾讯t3-t4标准精品php架构师教程目录大全,只要你看完保证薪资上升一个台阶(持续更新)

以上内容希望帮助到大家,很多phper在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、tp6,laravel,yii2,redis,swoole、swoft、kafka、mysql优化、shell脚本、docker、微服务、nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要的可以加入我的官方群点击此处。

《依赖注入与哪些事情无关?.doc》

下载本文的Word格式文档,以方便收藏与打印。