0

0

Yii框架的IoC容器和Service Locator区别_设计模式对比【避坑】

絕刀狂花

絕刀狂花

发布时间:2026-03-18 08:55:31

|

529人浏览过

|

来源于php中文网

原创

Yii::$app->get()调用的是Service Locator而非IoC容器,它仅按名称查找并缓存实例,不解析类型提示或自动注入依赖;真正的IoC功能由yii\di\Container提供,需显式调用且不干预应用组件获取流程。

yii框架的ioc容器和service locator区别_设计模式对比【避坑】

Yii里Yii::$app->get()调的是Service Locator,不是IoC容器

很多人以为Yii的Yii::$app->get('db')是在用IoC容器做依赖注入,其实不是。Yii应用实例(Yii::$app)本身是一个ServiceLocator,它只负责“按名找对象”,不参与构造逻辑、不解析类型提示、也不自动注入依赖。

真正实现IoC能力的是yii\di\Container类,但它默认**不接管应用组件的获取流程**——除非你显式用它来构建对象,比如$container->get(MyService::class)

  • ServiceLocator是“名字→实例”的简单映射,缓存已创建的实例,适合配置固定、生命周期长的组件(如dbcache
  • Container支持构造函数注入、方法注入、接口绑定、单例/原型作用域,但需要你主动调用它,且不会自动替换Yii::$app->get()的行为
  • 如果你在config/web.php里写'components' => ['db' => [...]],这些组件由ServiceLocator管理;而'container' => ['definitions' => [...]]才影响Container

想让Controller里自动注入服务?别指望ServiceLocator,得配Container并改用构造函数

Yii默认Controller是通过ServiceLocator创建的,所以__construct()参数不会被自动填充。哪怕你在container里绑定了MyService::classnew SiteController()也不会触发注入。

要启用构造函数注入,必须两步走:

  • 在应用配置中设置'container' => ['definitions' => [MyService::class => MyService::class]]
  • 把Controller注册为Container可管理的对象,例如在bootstrap或模块中手动用$container->get(SiteController::class),而不是靠Yii::$app->createController()

否则你会看到Missing required parameters for controller constructor这类错误——这不是配置漏了,是根本没走Container的解析链。

ContainerServiceLocator混用时,set()行为完全不同

都叫set(),但语义天差地别:

MidReal AI
MidReal AI

MidReal AI是一款革命性的AI小说生成工具,同时也是一个文本互动冒险游戏平台。

下载
  • $serviceLocator->set('db', $config):注册一个“工厂回调”,下次get('db')时才执行,返回单例实例
  • $container->set(MyService::class, $config):注册一个“类定义”,下次get(MyService::class)时才构造,可设为每次新建(['class' => ..., 'singleton' => false]
  • 更关键的是:$container->set('db', ...)不会影响Yii::$app->get('db'),因为ServiceLocator根本不查Container

常见坑:有人在containerset('db', ...),然后期待Yii::$app->get('db')返回新配置的实例——结果还是老的,因为两个系统完全隔离。

复杂依赖链下,Container能解耦,但ServiceLocator会悄悄藏住问题

比如OrderService依赖PaymentGateway,而后者又依赖Logger。用Container可以清晰绑定:$container->set(LoggerInterface::class, FileLogger::class),所有层级自动注入。

但如果全靠ServiceLocator,你得在OrderService里写Yii::$app->get('paymentGateway'),再在PaymentGateway里写Yii::$app->get('logger')——这等于把依赖硬编码进实现,测试时没法替换,也看不出哪里用了什么。

最隐蔽的问题是:当PaymentGateway某天开始需要一个新依赖,你得手动改它的构造函数+所有调用点,而Container只要补一条set()就能透传下去。没人报错,但重构成本已经悄悄翻倍。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

2038

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

682

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2448

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

49

2026.01.19

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

951

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

32

2025.12.06

PHP Yii框架专题
PHP Yii框架专题

本专题专注于PHP主流框架Yii的应用,系统讲解MVC架构、路由机制、数据库操作、表单处理、安全验证与RESTful API 开发等核心内容。通过电商网站、后台管理系统与内容管理平台等实战项目,帮助学员快速掌握Yii框架的开发技巧与实战经验。

91

2025.09.04

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

22

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号