隐式接口实现(ImplicitInterfaceImplementation)
译自:Martin Fowler's Bliki 2006.01.04
EN:ImplicitInterfaceImplementation
JP:暗黙的インタフェースの実装
Java和C#拥有同样的模型:单纯接口类型(pure interface types)[注1]
. 我们可以声明一个Pure Interface使用这样的代码:
Interface
Mailable, 接着我们也可以定义他的一个实现:class Customer implements Mailable (in Java).
一个类可以实现多个Pure Interface.
这一模型存在一个问题,他忽略了这样一个事实: 一旦我们拥有了一个Class, 那么我们便拥有了一个与之相应的隐式接口(Implicit Interface). 以上述的Customer类为例, 其隐式接口是指在Customer中声明的所有Public方法所组成的接口(这种隐式接口的概念在我所见过的OO语言中,都存在).使用Java也好, C#也好, 实现一个隐式接口是办不到的, 也就是说我们不能写出形如下面这样的代码:"Class ValuedCustomer implements Customer".
实现一个隐式接口是什么意思呢?本质上, 他将告诉类型系统, 类ValuedCustomer实现了Customer类中声明的所有public方法,并忽略了他的实现. Customer类的实现包括, 其public方法的实现, 非public方法,以及数据. 也就是说我们拥有了接口继承, 而非实现继承.
拥有隐式接口的这样一个Customer类, 就如同我们拥有了两个东西, 其一是"Customer接口", 该接口里面含有Customer类的所有Public方法, 其二是一个"CustomerImpl"类, 他实现了"Customer接口".
隐式接口这一特性会给我们带了什么便利?
答案之一是在Java的初期, 因为还没有现在这样的Collections框架, 所以我经常想将Vector替换成我自己的实现。但是很遗憾,我们办不到,因为Vector是一个类,我们只能子类化他。我曾一次次的遭遇这样的场面,只是因为我使用的库并没有给我提供相应的接口,以允许我切换实现。是的,没有隐式接口实现,我们没发做到这些。
另一个特别的原因是测试问题, 因为没有接口, stub的时候常常很难, 甚至不可能。这种情况下,我们经常只是为了将来能够进行替换实现,而去定义了一个接口。这种InterfaceImplementationPair方法,能解决这个问题。但是我更喜欢隐式接口实现,因为他更加清晰易读。
但是,为什么编程语言没有允许这一特性呢?我不知道,因为我不是一个语言设计者。但有一次,我有机会与Anders Heljsberg[注2]
讨论这一问题,得到的答案是他更偏好于:“只有你显示的声明了一个成员为Virtual,你才可以对他进行覆写(overriding)”[注3]
。这实质上是担心子类(或者实现者,更确切的说)会破坏其父类,这涉及到如何使用继承,他只适合晚餐后来讨论,这里我不打算详细说明。
这一问题在动态语言中不存在,其他的类如果想实现一个对象的接口时,只需要实现与该对象相同的方法即可。在Java中的动态代理也是解决该问题的一个方法,尽管我认为隐式接口实现要更清晰可读。
Mike Rettig指出了隐式接口实现的一个问题:并非所有的用户都只使用类的Public方法。试想PaymentPlan与Customer类在同一个包中,那么他可以调用Customer类中具有包可见性的方法。那么如果使用Customer的一个隐式接口实现的类,去替换Customer类,PaymentPlan便会出错(译注:因为拿去替换的类已经不再拥有Customer类中具有包可见性的方法)。
Mike Rettig指出的问题是:一个类有多个隐式接口,同时每一个隐式接口又有不同的访问权限控制(译注:包可见性方法与public可见性方法便不完全在同一隐式接口中)。同样的一个类,对其他某些实例,会允许范围更广的访问。
注1:为了与ImplictInterface想对应,我本想把这里翻译成显示接口,但为了与原为对应,这里翻译成了单纯,日语中被翻译成了纯粹。
注2: Anders Heljsberg
: turbo pascal, delphi, C#等的作者
注3: 这句话我的理解是,1.隐式的接口继承确实会舍弃一些父类一些东西(属性,非public方法,public方法的实现),这当然是对父类的一种破坏。2. 对于"只有显示声明为Virtual,才能进行覆写"这句话,我理解他也是对“子类不破坏父类”的一种保护,因为如果如果父类的作者不显示声明为Virtual,那么你便不可以对该方法覆写,进而你也无法展开多态。此时程序的设计者拥有更多的控制权(责任)。
分享到:
相关推荐
光伏风电混合并网系统Simulink仿真模型:光伏发电与风力发电的协同控制与并网逆变器设计,光伏风电混合并网系统simulink仿真模型。 系统有光伏发电系统、风力发电系统、负载、逆变器lcl大电网构成。 光伏系统采用扰动观察法实现mppt控制,经过boost电路并入母线; 风机采用最佳叶尖速比实现mppt控制,通过三相电压型pwm变器整流并入母线; 并网逆变器VSR采用基于电网电压定向矢量控制双闭环,经过lcl滤波器并入大电网。 ,核心关键词: 1. 光伏风电混合并网系统 2. Simulink仿真模型 3. 光伏发电系统 4. 风力发电系统 5. 负载 6. 逆变器LCL大电网 7. MPPT控制 8. 扰动观察法 9. Boost电路 10. 最佳叶尖速比 11. 三相电压型PWM变换器 12. VSR电网电压定向矢量控制双闭环 13. LCL滤波器 以上关键词用分号分隔为: 光伏风电混合并网系统;Simulink仿真模型;光伏发电系统;风力发电系统;负载;逆变器LCL大电网;MPPT控制;扰动观察法;Boost电路;最佳叶尖速比
DXP元器件库,初学者有用
2025专业技术人员继续教育公需课题库(附含答案).pptx
C++编写的资产管理系统(带SQLServer数据库文件。)。
Simulink下的MATLAB平台在智能电网微网运行控制中的并网仿真与逆变器控制策略探讨,Simulink:智能电网微网运行控制仿真及其参考资料 关键词:微电网 运行控制 仿真平台:MATLAB 主要内容:并网仿真 逆变器控制 下垂控制 ,关键词:微电网; 运行控制; Simulink仿真; MATLAB; 并网仿真; 逆变器控制; 下垂控制; 智能电网微网。,"Simulink在MATLAB平台下的微电网运行控制仿真研究及资料整合"
Matlab中的HMM隐马尔科夫与Markov马尔科夫时间序列预测源代码及数据集(可运行,适用于单变量预测),HMM隐马尔科夫时间序列预测 Markov马尔科夫时间序列预测(Matlab) 1.所有程序经过验证,保证可以运行 2.程序包括源码(主程序一个,子函数两个)和数据集; 3.程序适用于单变量时间序列预测。 注意:HMMP为主程序、data为数据集,其余m文件为函数文件,运行主文件HMMP即可。 ,HMM隐马尔科夫模型; 时间序列预测; Matlab程序; 验证可用; 主程序; 函数文件; 单变量预测; 包含源码与数据集。,"HMM与马尔科夫模型结合的时间序列预测程序(Matlab)验证版"
项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载 技术组成 语言:java 开发环境:idea 数据库:MySql8.0 部署环境:Tomcat(建议用 7.x 或者 8.x 版本),maven 数据库工具:navicat
python学习练习游戏案例,详细备注解释代码,最适合初学者,练手学习,资源已上传欢迎下载学习
三菱FX系列自由口通讯程序详解:FX3U-232BD与上位机通讯及PLC与触摸屏应用,三菱FX自由口通讯程序 三菱FX系列自由口通讯程序 利用FX3U-232BD与上位机自由口通讯, 有PLC程序和触摸屏程序,通过连接三根线即可通讯 具有很好的学习意义和借鉴价值。 ,核心关键词:三菱FX系列; 自由口通讯程序; FX3U-232BD; 上位机; PLC程序; 触摸屏程序; 三线连接; 学习意义; 借鉴价值。,三菱FX系列自由口通讯程序:简易编程与实用连接指南
1990-2022年各省份基尼系数
Python自动化办公源码-60 pandas-matplotlib
MATLAB下的模型预测控制在楼宇负荷需求响应中的研究与应用:结合热力学与舒适度考量,MATLAB代码:基于模型预测控制的楼宇负荷需求响应研究 关键词:楼宇负荷 空调 模型预测控制 需求响应 参考文档:《Model Predictive Control of Thermal Storage for Demand Response》完全复现 仿真平台:MATLAB+CVX平台 主要内容:代码主要做的是一个建筑楼宇的需求响应问题,首先利用楼宇的储热特性,结合热力学方程构建了其储热模型,其次,考虑在动态能量电价的引导下,对楼宇负荷进行需求侧管理,从而能够对其负荷曲线进行改善,在需求响应的过程中也考虑了用户的舒适度,相对来讲比较全面,模型的求解采用的是较为创新的模型预测控制算法,更加创新,而且求解的效果更好,店主已经对代码进行了深入的加工和处理,出图效果非常好,代码质量非常高 ,关键词:楼宇负荷; 空调; 模型预测控制; 需求响应; 储热模型; 动态能量电价; 舒适度; MATLAB代码; CVX平台; 深入处理。,基于MATLAB的模型预测控制研究:楼宇负荷需求响应管理与优化
Prius 2004永磁同步电机设计报告:从理论到实践——磁路法、Maxwell仿真建模与温升分析,Prius2004永磁同步电机设计报告: 磁路法、maxwell有限元法、MotorCAD温仿真、应力分析。 (内容比较完善,用于很需要的朋友,不支持讲解,等额外服务哈。 ) 内容:: 1.Excell设计程序,可以了解这个电机是怎么设计出来的,已知功率转矩等,计算电机的体积,叠厚,匝数等。 2.Maxwell参数化仿真模型:可以学习参数化仿真模型,有限元结果可查看。 3. 橡树岭拆解和实测数据:官方的实测数据和差拆解报告。 4.maxwell prius2004建模仿真教程等:ppt资料一步一步教学怎么去建模 5.温升仿真分析,提供motor cad模型 ,磁路法; Maxwell有限元法; MotorCAD温仿真; 应力分析; Excell设计程序; Maxwell参数化仿真模型; 橡树岭拆解实测数据; Maxwelli Prius 2004建模仿真教程; 温升仿真分析; Motor CAD模型。,2004款Prius永磁同步电机设计报告:Excell程序与Maxwell有限元法融
基于Voronoi理论的维修站点选址算法研究.pdf
料箱输送线程序:PLC设备布局图及电气图纸集成系统(包含MultiControl控制卡等,采用STL开发,仅供学习参考),料箱输送线程序,带目的地跟踪,提供设备布局图和电气图纸以及博途程序。 程序语言较多使用了STL,程序仅供学习参考。 硬件配置:PLC:1515-2 PN HMI:TP700 Confort 主要设备有:英特诺直流辊筒电机,控制卡MultiControl;条码阅读器Sick CLV620; 和MiniLoad堆垛机通过Anybus模块通讯;称重模块品牌碧彩BIZERBA;还有使用丹佛斯变频器的提升机。 ,料箱输送线程序; 目的地跟踪; 设备布局图; 电气图纸; 博途程序; STL语言; PLC硬件配置; 英特诺直流辊筒电机; 控制卡MultiControl; 条码阅读器Sick CLV620; Anybus模块通讯; 称重模块碧彩BIZERBA; 丹佛斯变频器提升机。,"多设备集成:带目的地跟踪的料箱输送线博途程序"
1、资源内容地址:https://blog.csdn.net/2301_79696294/article/details/144634074 2、数据特点:今年全新,手工精心整理,放心引用,数据来自权威,且标注《数据来源》,相对于其他人的控制变量数据准确很多,适合写论文做实证用 ,不会出现数据造假问题 3、适用对象:大学生,本科生,研究生小白可用,容易上手!!! 4、课程引用: 经济学,地理学,城市规划与城市研究,公共政策与管理,社会学,商业与管理
2025网络安全法竞赛题题库及参考答案.pptx
CAN总线在小电流接地故障检测中的应用.pdf
三菱步进电机驱动器控制定位案例:触摸屏PLC程序实现正反转、原点回归及急停报警功能详解,三菱步进电机驱动器控制的定位案例,带有触摸屏程序,plc程序 程序功能实现正反转控制,原点回归,急停报警等 触摸屏有报警显示,故障历史这些常用的画面设置,对控制多轴运动很有帮助,值得去学习一下 ,核心关键词:三菱步进电机驱动器;定位控制;触摸屏程序;PLC程序;正反转控制;原点回归;急停报警;报警显示;故障历史;多轴运动控制。,"三菱步进电机驱动:触摸屏PLC程序化控制多轴定位系统"
2025最新工业机器人考试题库及答案.doc