免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1436 | 回复: 9
打印 上一主题 下一主题

大家说说,怎样算一个优秀的模块或库 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-26 17:38 |只看该作者 |倒序浏览
最近比较烦,每个人的开发理念或许都不一样,
也许有人觉得功能实现就ok了,别人怎么用我这个模块无伤大雅,
说得太多吧,人都是由自尊的。无论如何,还是有必要大家达到认同的。。


一堆散乱的宝石,无论如何也成就不了一座水晶宫殿,
大家说说,该如何打磨这些宝石呢?

1. 如非必要不可,不引入全局资源(或变量)
2. 定义面向命令的接口,而不是面向实现过程的接口。
    亦即使用这个模块,只需要告诉模块 "去做什么", 而不是告诉模块 "如何去做".
3. 一致的命名规范,并且望文可生义
4. 有始有终,负责取得某资源,就要负责释放该资源

论坛徽章:
0
2 [报告]
发表于 2007-03-26 17:44 |只看该作者
“低耦合高内聚”,这帖子应该到软件工程版发

论坛徽章:
0
3 [报告]
发表于 2007-03-26 17:51 |只看该作者
原帖由 C_C 于 2007-3-26 17:44 发表
“低耦合高内聚”,这帖子应该到软件工程版发


恕我直言,软件工程版里,大多是没有开发经验的菜鸟,说说概念还行,不会有切肤之痛。

论坛徽章:
0
4 [报告]
发表于 2007-03-26 17:53 |只看该作者
请教:能否举两个简单例子说明下何为“面向命令的接口”,何为“面向实现过程的接口”。

论坛徽章:
0
5 [报告]
发表于 2007-03-26 17:58 |只看该作者
原帖由 飞灰橙 于 2007-3-26 17:51 发表


恕我直言,软件工程版里,大多是没有开发经验的菜鸟,说说概念还行,不会有切肤之痛。


有概念总比没概念的好吧

论坛徽章:
0
6 [报告]
发表于 2007-03-26 18:00 |只看该作者
原帖由 C_C 于 2007-3-26 17:58 发表


有概念总比没概念的好吧


那是当然
不过因为更想请教大家关于C/C++设计和实作时的建议,所以发在此版。

论坛徽章:
0
7 [报告]
发表于 2007-03-26 18:05 |只看该作者
原帖由 一梦如是 于 2007-3-26 17:53 发表
请教:能否举两个简单例子说明下何为“面向命令的接口”,何为“面向实现过程的接口”。


JAVA的JNDI和实体BEEN这两种接口就是很好的例子

论坛徽章:
0
8 [报告]
发表于 2007-03-26 18:11 |只看该作者
原帖由 一梦如是 于 2007-3-26 17:53 发表
请教:能否举两个简单例子说明下何为“面向命令的接口”,何为“面向实现过程的接口”。


比方说实现一个准备饮品的模块,
应该是泡茶就只需调用"泡茶",冲咖啡就只需调用"冲咖啡".
面向过程的接口可能是:

泡茶:
    obj.取茶杯;
    obj.取茶叶;
    obj.冲开水;

冲咖啡:
    obj.取咖啡杯;
    obj.取咖啡;
    obj.加糖;
    obj.冲开水;
    obj.搅拌;

一个面向命令的接口,应该是:
    obj.去泡茶;
    obj.去冲咖啡;

真是一个理念的问题。

论坛徽章:
0
9 [报告]
发表于 2007-03-26 18:14 |只看该作者
原帖由 飞灰橙 于 2007-3-26 18:11 发表


比方说实现一个准备饮品的模块,
应该是泡茶就只需调用"泡茶",冲咖啡就只需调用"冲咖啡".
面向过程的接口可能是:

泡茶:
    obj.取茶杯;
    obj.取茶叶;
    obj.冲开水;

...


实际上这是谁负责做这件事的问题,
并不是将几个函数简单的压缩。
如果始终有"这件事情该谁负责"的概念,那就对了

论坛徽章:
0
10 [报告]
发表于 2007-03-26 18:27 |只看该作者
人的观念是最难转变的,特别对于那些抗拒改变的人。
我在这方面也有很深刻的体会,很多时候不是技术问题,,,,

看看“第5项修炼”吧,如何创建学习型组织,呵呵。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP