概念的包含与交叉 - 类的合成与继承

笨人是无法理解一个塞满各种复杂功能的对象,所以类的第一设计原则是单一,对应问题空间中的一个概念。如果所对应的概念包含其它概念,却为整体/ 部分关系,称之为"has-a",我们就将这几个类的实例合成(composition)一个新类。例如商船都有动力装置,那么我们就实例化一个动力装置类,加上除动力装置范畴以外的其它属性和方法,即合成商船类,如图2。合成具有极大的灵活性,且不破坏类的封装。所以我们要尽量使用合成,少用下面介绍的继承(合成复用原则Composite Reuse Principle)。

小时候的娱乐方式比较少,映入眼框的除了山水外,最多的莫过于五六十年代战争题材的老电影,里头人物脸谱化得严重,以至于我总认为,这个世界只有两种人--好人和坏人,如果这个观点成立,那么合成将一往无前。但这个世界上,并不全是整体都由部份简单叠加。现在让我们假设这个世界的船只有两种用途:商船和战船,从概念的角度来看,它们有相拟性,即概念交叉,如图6-3左,同时它们也具有各自的特点,如果我们只是简单地将商船和战船分别抽象成两个类,那么将出现大量的类成员重复,所以需要构造一个机制来反映两个概念的交叉关系,这就是继承(inheritance)的由来,称之为"is-a"。

继承的特点是具有层次性,从图的外形来看很象家谱树,但用家谱树来比喻继承是愚蠢的,并没有真正揭示继承的实质,继承的过程,就是从一般到特殊的过程,如图3右所示。传说中人类都是由非州一古猿的后代,事实与否我们先不讨论,但与之类似的是,如果层层抽象,.NET的所有类都直接或间接派生于同一个基类--Object类。

类的继承最直观的用处在于复用,.NET技术给我们第一映像就是MS公司工程师们经过长期实践提炼出的五千多个公共类,对于应用而言,它几乎涵盖了目前为止所有领域的一般化概念。在此基础上通过适当的继承与合成,我们很快就能构架出属于自己的类系。

我们再以成员集合的观点看待类,对于合成而言,其成员集合如下:

商船{位置,船向,动力装置{动力值},移动(方向)}

引用动力值需要如此表达:商船.动力装置.动力值(你可以尝试一下把"."读成"的"),而对继承而言,其成员集合如下:

·商船{最大运载量,装载(货物),移动(方向)}

·战船{火力值,战斗(船),移动(方向)}

可以看出船类的public成员变成商船类的public成员,表达为:商船.移动,而船类的private成员在商船类中被隐藏。这么处理的依据是:因为船能移动,商船是船,所以商船也能移动(著名的亚里士多德三段论)。有时我们希望派生类能访问基类的某个成员但又对类以外的世界隐藏,如船的速度,各种种类的船都应该有速度,所以速度应该是基类成员,但我们不希望外界因素来直接修改速度值以破坏速度的计算机制(其同时受内外因素影响,由船的移动方法来计算),所以我们引入第三个访问控制符protected来修饰该类成员。

战船有一个有趣的方法:战斗(船),接口的参数是船类的一个实例,也就是说战船可以和任何一种船战斗,甭管是你商船还是战船,所以我们可以这么使用该方法: 俾斯麦.战斗(泰坦尼克号),即子类型可以替换基类型(依然可以用亚里士多德三段论来证明这个逻辑),这种替换方法称之为里氏代换原则(Liskov Substitution Principle),作用是减小方法实现的复杂度。

继承机制有一个重要的缺陷,基类和派生类是强耦合关系,且破坏了封装,由此带来问题是:如果基类因为设计不当而进行修改,将影响所有派生类;另外,对于派生类的某个成员而言,你可能要花半天时间才能找到它究竟是在哪层实现,所以在设计过程中,一要尽量压缩继承的层数,二是坚持合成复用原则,能用合成就不用继承。

Login类的类视图

ASP.NET入门随想六之大航海家(2)相关推荐

  1. ASP.NET入门随想六之大航海家(1)

    多隆云:我和韦春花的关系是很纯洁的:杨振宁言<易经>思想阻碍了中国近代科学的发展:逻辑学家论:概念间的关系有五种,即同一.包含.交叉.分离.互斥.而康托尔却认为:关系是有序偶. ■ 我要懒 ...

  2. [ASP.NET入门随想七]主角与配角——OO思想的多态、接口与委托

    [ASP.NET入门随想七]主角与配角 --OO思想的多态.接口与委托 曾几何时,我们的父辈接受到的对美好生活的描绘是:"楼上楼下.电灯电话",三十年过去了,电灯电话早已已成为我们 ...

  3. [ASP.NET入门随想十] 珍珠奶茶 ——服务器控件模型

    [ASP.NET入门随想十] 珍珠奶茶                     --服务器控件模型 他迷上了珍珠奶茶.说实话,以前他一直觉得珍珠奶茶挺蠢的,真不知道是那一个天才的点子,居然把粉圆和泡沫 ...

  4. [ASP.NET入门随想五]金庸群“粒”传——OO思想的对象与类

    [ASP.NET入门随想五] 金庸群"粒"传 -- OO思想的对象与类 几年前一位名叫姚壮宪的失恋青年编出的李逍遥红遍大江南北,他那现实无法实现而杜撰出的一夫多妻艳运让我家奔一电脑 ...

  5. ASP.NET入门随想之博德之门 类与实例

    asp.net入门随想之博德之门 类与实例 内力衡量人的武学修为,而逍遥派的北冥神功实在是宝贝,习此术之人,全身如同一个黑洞,瞬间就将他人一辈子的修炼积累掠为已有,美名其曰"北冥大水,非由自 ...

  6. ASP.NET入门随想之吸星大法

    <script language='javascript' src='http://www.shiqiaotou.com/donetk/Header.js'></script> ...

  7. ASP.NET入门随想之金庸群“粒”传

    <script language='javascript' src='http://www.shiqiaotou.com/donetk/Header.js'></script> ...

  8. ASP.NET入门猜想

    ·天极开发者网络倾情奉献:http://dev.yesky.com/ ·策划:方舟 [023-86583043] 与老燕聊天会感到他比较激进,看他的文章却有与一个理性的人对话的感觉.这种激进和理性在老 ...

  9. .NET沉思集 ASP.NET入门猜想

    认识ASP.NET开发环境 开卷有益?- 开篇 写了六七年的ASP代码,风起云涌之际,不得以重启炉灶,用起ASP.NET.[全文] 瘦子与胖子的故事--WEB程序员的编程环境与任务 冯骥才曾经讲过一篇 ...

最新文章

  1. 2022-2028年全球与中国乳胶丝市场研究及前瞻分析报告
  2. SAP有用的NOTE(持续更新)
  3. java 毫秒转为日期_java将毫秒转化为日期
  4. 零基础基于U-Net网络实战眼底图像血管提取
  5. 主流浏览器内核介绍(前端开发值得了解的浏览器内核历史)
  6. 数据结构与算法之完全二叉树的节点个数
  7. c语言学生考勤系统课设报告,C语言课程设计总结报告学生考勤系统设计
  8. UVALive 4329 Ping pong
  9. linux 驱动基础知识(2)---设备树
  10. 大三上学期学期总结及百度实习感受
  11. Week15 - 程序设计思维与实践 - 字符串算法
  12. Android平台快速集成当下流行平台分享
  13. R语言学习记录:主成分分析的R实现
  14. Ps制作食物网站展示
  15. 法国计算机与技术先进学校,法国计算机专业大学排名(2020年泰晤士)_快飞留学...
  16. oracle导出辅助账明细,AO2011导入国库集中支付系统3.0的辅助账
  17. 关于Titan的中文整理
  18. 多模态特征表示和融合
  19. PLSQL:导出表结构、导出整个表、导出表部分数据、复制表、导入表
  20. Unity 3D 泰课网小球移动 相机跟随

热门文章

  1. 我喜欢的firefox插件及我的个性化firefox
  2. 【MCU】MDK错误:No Browse Information available in ‘..\OBJ\SPI‘
  3. 零基础CSS入门教程(9)——背景颜色和背景图片
  4. C++的继承,封装,多态
  5. 赶走抑郁,床头常备一本励志书
  6. CentOS 服务器性能查看
  7. 企业线上活动如何做虚拟直播?如何搭建3D虚拟场景直播间?
  8. 海量非结构化数据副本难保护,焱融科技携手英方推出联合解决方案
  9. SIGKILL与SIGTERM的区别
  10. 西部专属的云安全人才培养计划长啥样?