本帖最后由 Jmhh247 于 2017-5-19 16:58 编辑
作者:在好
链接:
https://www.zhihu.com/question/20925030/answer/102239120
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
那些年搞不懂的高深术语——依赖倒置•控制反转•依赖注入
•面向接口编程
那些年,空气中仿佛还能闻到汉唐盛世的余韵,因此你决不允许自己的脸上有油光,时刻保持活力。然而,你一定曾为这些“高深术语”感到过困扰。也许时至今日,你仍对它们一知半解。不过就在今天,这一切都将彻底改变!我将带领你以一种全新的高清视角进入奇妙的编程世界,领略涵泳在这些“高深术语”中的活泼泼的地气,以及翩跹于青萍之末的云水禅心。
5.jpg (16.1 KB, 下载次数: 0)
下载附件
2017-5-19 16:40 上传
比如OMCS网络语音视频框架,它实现了多媒体设备(麦克风、摄像头、桌面、电子白板)的采集、编码、网络传送、解码、播放(或显示)等相关的一整套流程,可以快速地开发出视频聊天系统、视频会议系统、远程医疗系统、远程教育系统、网络监控系统等等基于网络多媒体的应用系统。然而,OMCS直接支持的是通用的语音视频设备,而在某些系统中,需要使用网络摄像头或者特殊的视频采集卡作为视频源,或者其它的声音采集设备作为音频源,OMCS则提供了扩展接口——用户自己实现这个扩展的接口,然后以“依赖注入”的方式将对象实例注入到OMCS中,从而完成对音、视频设备的扩展。
“依赖注入”常常用于扩展,尤其是在开发框架的设计中。从某种意义上来说,任何开发框架,天生都是不完整的应用程序。因此,一个优秀的开发框架,不仅要让开发者能够重用这些久经考验的的卓越的解决方案,也要让开发者能够向框架中插入自定义的业务逻辑,从而灵活自由地适应特定的业务场景的需要——也就是说要具备良好的可扩展性。比如上面提到的OMCS网络语音视频框架可应用于音、视频聊天系统、视频会议系统、远程医疗系统、远程教育系统、网络监控系统等等基于网络多媒体的应用系统;以及ESFramework通信框架能够应用于即时通讯系统,大型多人在线游戏、在线网页游戏、文件传送系统、数据采集系统、分布式OA系统等任何需要分布式通信的软件系统中——这种良好的扩展性都与“依赖注入”的使用密不可分!
•面向接口编程
谈到最后,“面向接口编程”已经是呼之欲出。无论是依赖倒置、控制反转、还是依赖注入,都已经蕴含着“面向接口编程”的思想。面向接口,就意味着面向抽象。作为哲学范畴而言,规定性少称为抽象,规定性多称为具体。而接口,就是程序中的一种典型的“抽象”的形式。面向抽象,就意味着面向事物的本质规定性,摆脱感性杂多的牵绊,从而把握住“必然”——而这本身就意味着自由,因为自由就是对必然的认识。
也许以上的这段论述太过“哲学”,但是“一本之理”与“万殊之理”本身就“体用不二”——总结来看,依赖倒置、控制反转、依赖注入都围绕着“解耦和”的问题,而同时自始至终又都是“面向接口编程”的方法——因此,“面向接口编程”天生就是“解耦和”的好办法。由此也印证了从“抽象”到“自由”的这一段范畴的辩证衍化。
“面向对象”与“面向接口”并非两种不同的方法学,“面向接口”其实是“面向对象”的内在要求,是其一部分内涵的集中表述。我们对于理想软件的期待常被概括为“高内聚,低耦合”,这也是整个现代软件开发方法学所追求的目标。面向对象方法学作为现代软件开发方法学的代表,本身就蕴含着“高内聚,低耦合”的思想精髓,从这个意义上来说,“面向对象”这个表述更加侧重于“高内聚”,“面向接口”的表述则更加侧重于“低耦合”——不过是同一事物的不同侧面罢了。
除此之外,我们也能从“面向接口编程”的思想中得到“世俗”的启迪——《论语》里面讲,不患无位,患所以立;不患人之不己知,患其不能也——就是教导我们要面向“我有没有的本事?”、“我有没有能力?”这样的接口,而不是面向“我有没有搞到位子?”、“别人了不了解我?”这样的具体。依我看,这是莫大的教诲! (完)
解耦合还是很重要的。
不然也不会出现linux系统下诸多优秀开源库和框架。
凡是吐槽模块化和解耦合的,只能说明做的东西太菜了或者规模太小,用不到团队开发;或者太具象了没有重复使用的价值。
自己闭门重复造轮子,当然不会有代码复用的需求。
形而上者谓之道,形而下者谓之器。
什么c,c++,都是形而下的“器”,其背后的思想才是“道”。如果把面向对象当成工具,就只是停留在器的层面。
面向对象就是说c++、类?笑话,去看看用c写的libjpeg里面输入输出接口结构体,那就是面向对象。
说面向对象没有经典成功案例?笑话,去看看linux arm源码,采用设备树抽象出设备树对象,降低了驱动与设备的耦合,这也是面向对象。
真正重要的是思想。架构错了,细节做的再好也要被扔进回收站。
别整天张口闭口天才程序员了。人家嗤之以鼻的是停留在工具层面争论c更好还是c++更好,只会码代码没有思想的人。
哈哈,说的好,回答的太犀利了
原谅我隔了这么久才看到大哥的回帖
这感觉就像是当年看到 尼古拉斯·沃斯(Niklaus Wirth) 那个公式一样 :数据结构 + 算法 = 程序。
多纯粹啊,不需要管什么语言、编译器,当然,也不需要管天才程序员
一周热门 更多>