《为耦合辩护,为继承伸冤》的补充

lhy 2001-08-16 05:43:33
《为耦合辩护,为继承伸冤》一文草草而成,又不太完整,
结尾处还打了个白条,可能易引起误解,先简介一下,在把大部
分回复一齐回复一下.这个白条可能在下次兑付.

《为耦合辩护,为继承伸冤》谈了两个问题:

一.耦合并不是绝对坏的东西,分5点讲
1.不耦合和低耦合在很多情况下不太可能被实现;
2.低耦合并不是最重要的事情重要;
3.低耦合有时没有多大好处;
4.高耦合也常常有好处;
5.高耦合带来的害处是可以化解的.

二.用继承并不一定比聚合耦合度高,分3点讲
1.高耦合的部分往往用继承实现,低耦合的部分往往用聚合
实现,所以带来的用继承比用聚合耦合度高的错觉;
2.聚合和相识关系有时也需要高耦合;
3.可以设法降低继承的耦合度.

我同意以下说法:“建模时用继承还是聚合,均可,哪种结
构表达最接近自然,就用哪种--先放下程序设计上的考虑。”
同时认为设计时用继承还是聚合也应尽量使用表达最接近自然的
那一种.

有人说:“继承少用最好,那仅仅是一种产生对象类别的方法,
使用对象的精髓还在于聚合. ”我只能说,聚合也那仅仅是一种产
生对象类别的方法,而且很抱歉,我至今不认为存在什么“使用对象
的精髓”.

至于“继承属于OOP范畴”好象是属于搞笑范畴.

“过多的继承会增加基类的修改难度,从而降低了设计的灵
活性”我认为有道理,但设计的灵活性主要应建立在一个不需要
大修改的基类的基础上,基类需要大改动很可能是从分析开始出
了问题.

接口与聚合和继承都没有直接关系,接口实际上是标准化的
封装,我所设想的继承接口是标准化的继承.

“pb也是由继承机制的,难道他就是面向对象的?” PB为什
么不能算面向对象的呢?“oo强调每个对象应该专注于某个功能。
应尽可能的把对象写的功能单一小巧。”结构化也强调每个模块
应该专注于某个功能,也应尽可能的把模块写的功能单一小巧。
“大部分时候,基本上都可以用delegate来代替了。”我的观点,
用delegate来代替继承不够自然,而且有缺陷,我将在其他文章中
专文讨论.

对于继承往往是静态的,我认为主要应通过改进继承机制来解
决,我也将在其他文章中专文讨论.

很多人言必称《设计模式》,就象基督徒对《圣经》,穆斯林
对《古兰经》一样.我个人以为《设计模式》不适合做面向对象设
计方面的启蒙读物,也不太适合做面向对象设计方面的《圣经》.
其他有关《设计模式》的问题,我还是将在其他文章中专文讨论.

很抱歉,第一个白条没兑付,又打了好几个白条.
...全文
78 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
wao 2001-08-21
  • 打赏
  • 举报
回复
一头雾水,呵呵.
我就喜欢继承,呵呵,不过是继承虚类.
notepad--v3.4 windows Notepad--v3.4.0-plugin-Installer.exe 是win10下面的插件版安装包,会关联右键菜单等。 Notepad--v3.4.0-win10-portable.zip 是绿色免安装版本,解压即用,不会关联右键菜单注册表。 Ndd-quick-v3.3.0-win10-single-portable.zip 是单文件绿色免安装版,只包含皮肤和vc依赖库,不含插件、不含文件对比,主推轻量级、快速反应。适合只需要纯粹、轻快级,文本编辑器的用户。不定期发布。 MacOS 版本 Notepad--v3.4.0-mac_x64_12.3.dmg 是macos 12.x 及以后的版本。 Notepad--v3.4.0-mac_arm64_12.3.dmg 是macos 12.x 及以后 arm64 m1/m2芯片 的版本。第一次安装时,需要在设置偏好里面,放开苹果的安装限制,才能正常识别,请自行放开设置一下。 如果还是有问题,参考帖子:#I8JTJN:macOS Sonoma 14.1.1安装提示已损坏:macOS Sonoma 14.1.1安装提示已损坏 uos com.hmja.notepad_3.4.0.0_amd64.deb 是x64 cpu架构的uos系统对应的ndd版本。 其余系统版本后续会发布。 3.4 修改如下: 1 支持文件标签拖入拖出到新窗口的效果。 2 windows下修改快捷键放开。 3 按行号切分大文件。 4 大文件打开时,在文件夹查找所在目录,macos下可能会崩溃问题。 5 目录右键增加删除文件、文件夹功能。 6 补充深色主题下rust语法高亮; lisp 语法失效问题。 7 linux下信号打开文件,不拿锁,打开文件在消息队列中去做。

1,268

社区成员

发帖
与我相关
我的任务
社区描述
软件工程/管理 管理版
社区管理员
  • 研发管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧