Soft_Job 板


LINE

先讲结论: DI(Dependency Injection) 跟 IoC(Inversion of Control) 的原始目的都不是解耦 接着说明一下 DI 跟 IoC: 首先 IoC 的目的是控制权的转移,如原 PO 文章里面原本是在 Employee 里面 new Address,而采用 IoC 之後这样的行为就转移到外部来决定 而之所以要转移控制权是为了好维护,例如可能 new Address 的行为将来要调整就不用 动到 Employee 而 DI 只是搭配 IoC 来将物件注入需要的物件当中,例如透过 Employee 的 Constructo r 来注入 Address 的实例 在这两个 pattern 当中都没有要求转移控制跟注入的物件是什麽,你要注入抽象或实作 都可以,也因此并不能直接帮助你解耦 而且 Spring 只是提供 DI/IoC 相关功能来帮助管控物件生命周期,并且降低自己实作的 复杂度,实际上你完全可以自己实作,例如在 main 自己写注入 如果你的目的是要解耦的话,要考虑的应该是 SOLID 里面的 DI(Dependency Inversion) ,利用抽象隔离实作 而且首先要说明的是一般软体在说得解耦都是指对实作解耦,毕竟两个元件要能协作,不 可能两边都完全不知道对方,而知道 (know) 对方就是一种耦合 SOLID 的 DI 就是利用抽象帮助你解耦 (strong coupling to weak coupling) 而在有抽象隔离的前提下,利用 DI/IoC 就能帮助你大幅降低後续修改实作的时候,元件 互相影响的可能性,并且方便测试,尤其是单元测试 接着利用 Spring 提供的 DI/IoC 功能可以更进一步减少实作的复杂度,让 DI 实作的 boiler plate 部分交给 Spring 管理达到关注点分离的效果,让你可以专注在逻辑面 以原 PO 的例子来说算是有用到 DI/IoC 的概念,但实务上以这个例子来说可能根本不需 要用到 Spring 的功能,而比较需要考虑的是 Address 跟 Employee 要如何互动 比较常见的例子是 Spring MVC 分层架构下要在 Controller 层使用 Service 或 Servic e 层使用 Repository 尤其是 Spring Data JPA 常用的 CrudRepository 或 JpaRepository 原本就是 interface,你根本不需要知道 Spring 帮你注入的实作是哪个,加上也只需要用 @Autowire 或 Contructor 方式注入,完全不须自己实作 new 的部分,甚至注入的实作 本 身的依赖也一并由 Spring 帮你搞定,达到关注点分离,让你可以直接在 Service 使用 Repository,藉此达到专注在 Service 本身的逻辑 结论: DI(Denpendency Injection) 跟 IoC(Inversion of Control) 的目的都不是为了解耦 要解耦先考虑用抽象隔离,再考虑用 Spring DI/IoC 的功能帮助降低实作的复杂度 至於抽象稳定那就是另外的问题了... --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 220.128.218.40 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Soft_Job/M.1648784531.A.A3A.html
1F:推 keroro01: 推分享 04/01 11:51
2F:推 ntpuisbest: 推04/01 12:24
3F:推 foreverk: 推,我前面的观念是SOLID的DI,混淆到Spring的DI了04/01 12:32
4F:推 nicetw20xx: 推 04/01 12:33
5F:推 kor525: 太神啦 04/01 13:42
6F:推 duck10704: 推 04/01 13:49
7F:推 ian90911: 推 04/01 14:12
8F:推 vencil: 推04/01 14:15
9F:推 liturtle: 推这篇,就是反转依赖的方向的04/01 15:24
10F:推 pinpigping: 推04/01 16:06
11F:推 gpctv: 推04/01 17:33
12F:推 alihue: 推04/01 18:08
13F:推 htury: 推优质文04/01 18:42
14F:推 Psyman: 推,谢谢说明! 04/02 00:51
15F:推 fantasychese: IoC是设计原则,DI是实现IoC的方式之一,另一种是04/02 04:15
16F:→ fantasychese: Service Locator。没有DI搭配IoC使用这种说法 04/02 04:16
抱歉,我用词不精准,你是对的 不过 FYI,实作 IoC 不止这两种方式
17F:推 Arctica: 舒服04/02 17:39
18F:推 stero: 这篇正解04/03 23:19
※ 编辑: LoadUp (58.114.218.201 台湾), 04/04/2022 10:29:33







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP