博客
关于我
[面向对象杂谈]接口
阅读量:446 次
发布时间:2019-03-06

本文共 1104 字,大约阅读时间需要 3 分钟。

人总是很忙的,但是一个人就是一个人,不存在分身术。

假设有个人王大柱,他是光明中学的校长,还是光明村的村委会成员,同时还是他儿子的父亲。

那么我们可以这么想:王大柱是一个类的具体的实现对象,这类名叫“王大柱类”,而王大柱类实现了三个接口:“I光明中学校长”、“I光明村村委会成员”、“I父亲”。

画图如下:

 

那么我们可以称这三个接口为这个类的三个“身份”。

我们可以这样制造一个王大柱出来:

王大柱类 王大柱 = new 王大柱类();

此时,“王大柱”这个变量就代表了[王大柱类]的实例。这个没问题吧?

 

戏剧性的事情来了。

>“王大柱”在学校是什么身份呢?按正常的角度,他应该是校长的身份,管理学校的方方面面才对。

>“王大柱”在村委会是什么身份呢?按正常角度,他应该是村委会成员,参与村委会的会议和讨论。

>“王大柱”在家里是什么身份呢?按正常的角度,他应该是他儿子的父亲,在家带孩子陪老婆。

 

所以接下来的代码大家看仔细了:

// 王大柱要以校长身份去开师生会议I光明中学校长  王校长 = 王大柱 as  I光明中学校长;王校长.召开师生会议();

我们知道,接口可以定义变量,也可以实例化对象(用于实例化的类必须实现该接口)。

现在,我用I光明中学校长这一身份,去定义“王校长”这个变量,或者说定义这张工作证,有了这张工作证,“王大柱”这个人,身份就会转化为"王校长",但是"王校长"还是王大柱,并不是第二个人。这就是说,我在上面用关键字new的“王大柱”,在内存(地球)中只有一个对象(人),接口定义的"王校长"这个变量,仅仅指向了wdz这个人,给了他一层校长的身份而已。

如下图:

 

熟悉C++指针/内存堆栈的同学一定不陌生,左边就是堆,右边就是栈,堆是真正的数据,而右边的“王大柱”、“王校长”,只是一些变量,真正的数据和变量之间的关系,在这里就是引用关系。

但是接口编程又有一个不同的特点,也是极为重要的一个特点:接口有自己的成员变量。

换句话说,“王大柱”在家里,不是学校的“校长”,校长给老师和主任发通知的功能就没了呀!难道向老婆儿子发命令?找打。

这就是身份的问题,接口可以为堆上的对象提供不同的身份,实现不同的功能。

 

再来看下面的代码:

// 王大柱要去开会I光明村村委会成员 王委员 = 王校长 as I光明村村委会成员;王委员.到村里开会();// 王大柱要回家做饭给儿子吃I父亲 王爸爸 = 王委员 as I父亲;王爸爸.给儿子做饭();

读者可以自己想象了吗?

 

附:OOP(面向对象编程)三大特征

封装、继承、多态

这三个特征一直持续到编程的“设计模式”及以后更高层次的编程中。

转载地址:http://czzfz.baihongyu.com/

你可能感兴趣的文章
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
查看>>
NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
查看>>
nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
查看>>
NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
查看>>
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>