阅读更多

27顶
0踩

编程语言

转载新闻 用 Unix 的设计思想来应对多变的需求

2012-05-04 10:18 by 正式编辑 nemohq 评论(14) 有11862人浏览
在软件设计领域,有很多设计模式可以参考。但本文作者另辟蹊径,从UNIX设计思想的角度来阐述什么是好的软件设计,什么样的设计可以把需求变更对软件开发的影响降到最低。

以下为原文文章

我曾经在《UNIX传奇》的下篇中写过一些关于UNIX的设计哲学和思想(这里重点推荐大家看一下《The Art of UNIX Programming》),以前也写过一篇《一些软件设计的原则》。不过,这些内容都太多了,记不住。其实,这么多年来,我的经验告诉我,无论是UNIX设计,还是面向对象设计,还是别的什么如SOA、ECB、消息、事件、MVC、网络七层模型、数据库设计等等,他们都在干三件事——解耦,解耦,还是解耦!所谓解耦,就是让软件的模块和模块间尽量少地依赖起来


一、现实当中的例子

让我先举几个现实生活中的例子:

1、现实社会中,制造灯具的工厂完全不关心制造灯泡的工厂,制造灯泡的工厂也完全不关心制造灯具的工厂。但是,灯泡和灯饰可以很完美地组合成用户所喜欢的样子。他们是怎么做到的?

2、互联网上,网站开发者完全不用关心用户在用什么样的操作系统,什么样的客户端浏览器 (当然事实上,浏览器的不标准也让网站开发者很头痛,这里只是举个例子)。反过来,用户也不关心网站开发者在用什么技术来开发网站。但是大家在完全不关心对方的情况下,却可以很正常地协同工作在一起。为什么?

这样的例子太多了。为什么可以做成这样呢?因为大家依赖的是同一个接口。灯具和灯饰并不互相依赖,它们依赖的是一个接口;网站开发者和网站的用户依赖的还是接口——HTTP协议。这就是面向对象的核心思想——依赖于接口而不是依赖实现,这也就是解耦。当你看过这两个例子以后,我希望你以后设计的软件至少不能比我们现实社会中的这些方法要差。不然,你就是在让社会倒退了。

你可能会说,这与UNIX和应对需求变化有什么关系?下面让我们再来看一下UNIX的设计。

二、UNIX设计的例子

下面是几个UNIX下的例子:

1、UNIX下,所有的硬件都可以通过文件的方式存取。于是,软件和硬件的耦合被解开了,操作系统只需要把硬件统统变成文件即可。而程序也只需要使用三个工具:一个是fd,一个是read(),一个是write(),就可以来操作任意的硬件了,这就是抽象,简单到不行。

2、UNIX下,所有的命令都可以用管道串起来(管道绝对是个伟大的发明),这样,所有的命令间的交互全部解耦到只依赖于STD_IN和STD_OUT设备上。最酷的是,用户可以使用管道任意地拼装那些命令,以完成各式各样的功能。管道这个设计思想可以映射为今天的Web Service,你可以任意地拼装各种Web Service。

看到这里,你会发现,这还是解耦,本质上来说,也是一种依赖倒置——OOD的精髓。但是,UNIX还不仅仅是这些。我们再来看几个例子:

1、UNIX下,软件都是绿色地安装。在iOS上更明显——各个程序间基本上互不干扰,这个程序产生的垃圾文件不会影响到另一个程序。你删除一个程序不会影响到另一个程序。你也可以删除这些程序,只要把内核留着,系统依旧可以启动。

2、UNIX下,你可以通过设置一些环境变量,让多种环境同时存在。例如,某个LAMP 用的是Apache 2.0、Mysql 4.0、PHP 4.0,而另一个个LAMP用的是Apache 2.2、Mysql 5.0、PHP 5.3,你不但可以方便地在系统中切换这两个环境,你甚至还可以同时启动它们。

3、UNIX下,你可以随意地替换你想要的程序。例如,你不喜欢bash,你可以替换成ksh/csh;你不喜欢awk,你可以替换成gawk;所有的东西都像零件一样,你不喜欢什么,你就可以替换什么。

这三个例子告诉了我们——当你把你的软件设计的耦合度非常低时,你就可以随意地组合,随意地安排你的系统。相当的灵活,灵活到Windows到今天都学不会。

三、应对需求变化

看到这里,你可能明白我想说的是什么了。你可能开始觉得怎么样的系统设计会更有效了。如果你还记得《Steve Y 对平台的长篇大论》,你就会知道我想说什么了。是的,我想说的就是,当你真正了解了UNIX的设计思想后,你会觉得今天的这些设计理念都是对UNIX设计思想的一种传承或是变种。这些设计理念就是:

  • 解耦、解耦、解耦。尽量地让你的模块不要在实现上耦合,而是耦合某个规范,某个标准
  • KISS、KISS、KISS。要做到高度解耦,你的模块就一定要很简单。当然不是说简单到只有几行代码,而是简单到只做一件事,并把这件事做到极致,然后通过某个标准拼装起来
  • 拼装、拼装、拼装。我想不起来是谁曾说过这样一句话:“当我想用一个模块的时候,我直接调用就好了,没有必要像C或Java一样,还要编译”。是的,拼装需要一个框架,需要一种标准协议,然后让所有的系统都耦合在这种规范上,各自独立运行。就像一个机器上的各个部件,当我觉得这个部件性能不好,换一个部件就是了(例如,当我们在尝试不同的算法的时候)。
你还可以再想想建材和家具市场,无论用户过来想要装修什么,我都可以满足用户的不同需求。只要要求是和家具装修相关,我基本上都能满足,不是吗?无论你怎么变,只要不变态,我基本上都可以满足你。这就是解耦、拼装带来的好处。

你可能会说我说得太简单了,或者,你可能觉得有一些系统这样做没必要。不错,我承认这一点。不过,你可以有选择的或多或少地试试(其实,我相信你已经在不自觉的或多或少的在使用这种方式开发软件了)。

  • 大小: 35 KB
来自: 酷壳
27
0
评论 共 14 条 请登录后发表评论
14 楼 dohkoos 2012-12-13 16:07
引用
UNIX下,软件都是绿色地安装。在iOS上更明显——各个程序间基本上互不干扰,这个程序产生的垃圾文件不会影响到另一个程序。你删除一个程序不会影响到另一个程序。你也可以删除这些程序,只要把内核留着,系统依旧可以启动。


这个就是个大笑话。也许古老的unix-like系统是这样,但现在的unix-like安装个软件的话,你就会发现依赖另一个package,装那个package时又发现依赖另一个library,就一直这样,反正依赖比较严重
13 楼 shirne 2012-05-07 10:53
耦合度低有它的好处,也有弊端,就是效率的问题。
关键是在这之间找一个平衡点。
系统的模块我不太了解,就拿一个简单的脚本来说:
每个函数都实现一个独立的功能,需用到就支调用。
这叫低耦合。
但某些模块,是需要多种功能,循环调用,如果把功能代码嵌入到里面,就可以提高效率。
但换成调用到公共模块,带来的就是效率的损失。
12 楼 wentao_tang 2012-05-07 10:16
其实 主要是在设计 和 过度设计间取得一个很好的平衡,这个才是比较困难的。
11 楼 sp42 2012-05-06 21:33
不错 顶 学习!
10 楼 hardPass 2012-05-06 10:26
有道理。但同时应该注意另外一个词:“过度设计”
9 楼 amcucn 2012-05-06 08:58
说起来容易,但做起来却是另外一回事,通常这样的思想大家都知道,难的是如何建立接口,每个人的站的角度不一样,定义的接口也不一样,所以最终很难定义一套可供大家完美使用的实现方案。
8 楼 xiaoyao3857 2012-05-06 00:18
楼主思想理解得很透彻啊,学校老师虽然偶尔会讲,但说出来时,总又没有说到实质有影响的话或例子!
7 楼 helloqiner 2012-05-05 21:41
越是真理越是简单。同样的道理,不同的人理解不一样。楼主的这篇文章值得想成为砖家级别的码农好好领悟下。
6 楼 xieye 2012-05-05 13:17
引用
例如,某个LAMP 用的是Apache 2.0、Mysql 4.0、PHP 4.0,而另一个个LAMP用的是Apache 2.2、Mysql 5.0、PHP 5.3,你不但可以方便地在系统中切换这两个环境,你甚至还可以同时启动它们。


嗯嗯,我知道。
5 楼 mathgl 2012-05-04 23:20
beyondqinghua 写道
你还可以再想想建材和家具市场,无论用户过来想要装修什么,我都可以满足用户的不同需求。只要要求是和家具装修相关,我基本上都能满足,不是吗?无论你怎么变,只要不变态,我基本上都可以满足你。这就是解耦、拼装带来的好处。

但是很多需求就是很BT,你懂的。


再bt的需求,只要能实现都会被还原到代码。
4 楼 weng 2012-05-04 21:11
好文章,得领悟
3 楼 beyondqinghua 2012-05-04 18:10
你还可以再想想建材和家具市场,无论用户过来想要装修什么,我都可以满足用户的不同需求。只要要求是和家具装修相关,我基本上都能满足,不是吗?无论你怎么变,只要不变态,我基本上都可以满足你。这就是解耦、拼装带来的好处。

但是很多需求就是很BT,你懂的。
2 楼 myaniu 2012-05-04 13:05
自从熟悉linux(unix)以后,设计软件一直都是这么干的,甚至一个系统中,都会同时采用多种开发语言,每个进程只关注一个问题,每种语言只用来开发它擅长的部分。以后复用也很容易。
1 楼 x_root 2012-05-04 12:58
引用
其实,这么多年来,我的经验告诉我,无论是UNIX设计,还是面向对象设计,还是别的什么如SOA、ECB、消息、事件、MVC、网络七层模型、数据库设计等等,他们都在干三件事——解耦,解耦,还是解耦!所谓解耦,就是让软件的模块和模块间尽量少地依赖起来。
有道理!

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 用UNIX的设计思想来应对多变的需求

    今天我也想从Unix设计思想的角度来说说什么是好的软件设计,什么样的设计可以把需求变更对开发的影响降低。(注意:这并不能解决用户或是PM的无理需求,面对无理需求,需要仔细分析需求,而用技术的手段无法搞定这个...

  • 用Unix的设计思想来应对多变的需求

    无论是Unix设计,还是面向对象设计,还是别的什么如SOA,ECB,消息,事件,MVC,网络七层模型,数据库设计,等等,他们都在干三件事——解耦,解耦,还是解耦!所谓解耦,就是让软件的模块和模块间尽量少地依赖起来...

  • 基于SpringBoot+Vue的“智慧食堂”设计与实现(Java毕业设计,包括源码、数据库、教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

  • 历届奥运会奖牌数据(1896-2024年).xlsx

    本次分享的数据为1896年-2024年(从雅典到巴黎)间奥运会奖牌数据,包括年份、届次、国家地区、名次、金牌、银牌、铜牌等数据,含免费下载链接 ## 一、数据介绍 数据名称:历届奥运会奖牌数据 数据范围:世界各国 样本数量:1877条 数据年份:1896年-2024年 数据说明:包括届次、国家、名次等数据

  • 基于SpringBoot+Vue的实习管理系统(Java毕业设计,包括源码、数据库、教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

  • 【人机交互】MATLAB直车道线检测.zip

    【人机交互】MATLAB直车道线检测

  • 基于SSM+JSP的KTV点歌系统+数据库(Java毕业设计,包括源码,教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:jsp 后台框架:SSM 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4

  • 基于SSM+JSP的课程在线教育资源管理系统(1)+数据库(Java毕业设计,包括源码,教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:jsp 后台框架:SSM 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4

  • 2023年计算机硬件的组装实验报告.pdf

    2023年计算机硬件的组装实验报告.pdf

  • springboot大学生租房系统 LW PPT.zip

    ava项目springboot基于springboot的课程设计,包含源码+数据库+毕业论文

  • Flutter分析:带有质量平衡部分机翼的MATLAB计算(含Elastic轴与中心对齐)

    内容概要:本文档主要针对含有质量平衡段(即弹性轴和重心重合点xa=0)的硬翼Flutter问题提供了MATLAB解决方案。文档通过迭代的方式对一系列参数(如频率比(fr)、弹性轴(E)和半径(r)等)进行操作,并利用贝塞尔函数(Kn)来评估flutter速度(UFhat),从而预测了不同质比(mu)下flutter的缩减速度变化情况。同时,文档包含了绘图命令以视觉展示减小颤振速度随质量比变化的趋势以及相应的MATLAB代码。 适合人群:航空工程、飞行器动力学领域的科研工作者,工程师及研究生。尤其是那些从事飞行安全性和稳定性研究的专业人士。 使用场景及目标:主要用于解决飞行器设计过程中遇到的具体颤振问题,能够为设计新型飞机或其他有翼飞行物体提供科学依据和技术支持。它还能够辅助教育,帮助相关专业的学生理解flutter现象及其预防措施。 其他说明:此文件是以数值方法探讨带质量平衡的翅膀颤振特性的实例,在工程上有着重要意义。对于希望深入学习此类问题的人来说,这是一个极好的参考资料和实验平台。然而,实际应用还需要进一步考虑真实条件下的复杂因素,因此需要更多的专业知识和背景资料的支持。

  • 基于JAVA的机场航班起降与协调管理系统&毕业设计&毕业论文&数据库&演示视频&源代码

    本次项目是设计一个基于JAVA的机场航班起降与协调管理系统。 (1)在经济可行性上来分析的话,该软件是机场内部使用的一个指挥协调软件,属于航空安全投资,本软件开发成本并不高,软件和服务器数据库可以用机场原有的数据库进行开发,比起空难给航空公司造成的损失来说九牛一毛。 (2)在技术可行性上来分析的话,该软件主要运用了Java技术、jQuery-easyui和Mysql数据库技术。Java是到目前来说最稳定的、最可靠的软件开发工具;jQuery-easyui虽然是比较新的前台开发技术,但是他的界面新颖整洁,适合于功能性软件的开发;Mysql数据库也是许多大公司都采用的软件项目开发数据库,不仅稳定而且性能可靠,可以用作本次软件的开发。 (3)在法律可行性上来分析的话,该软件使用的技术都为开源的软件开发工具和语言,虽然Java等开发技术都存在Sun公司的版权问题,但是Java技术是可以免费使用的,没有涉及到法律上的侵权。 (4)在方案可行性上来分析的话,此次软件开发的很大一部分精力都放在了软件的需求分析和设计方面,设计出来的软件可以很好地去实现我们所要完成的软件预先设计的功能。

  • 2023年计算机与通信网络实验报告.pdf

    2023年计算机与通信网络实验报告.pdf

  • 2023年四川省德阳市统招专升本计算机自考真题(含答案).pdf

    2023年四川省德阳市统招专升本计算机自考真题(含答案).pdf

  • 基于SSM+JSP的农产品供销服务系统+数据库(Java毕业设计,包括源码,教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:jsp 后台框架:SSM 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4

  • 篮球论坛系统--论文.zip

    Java项目基于springboot的课程设计,包含源码+数据库+毕业论文

  • 基于SpringBoot+Vue的致远汽车租赁系统(Java毕业设计,包括源码、数据库、教程).zip

    Java 项目,仅供学习参考。 Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

  • GUI面板MATLAB答题纸试卷自动识别.zip

    GUI面板MATLAB答题纸试卷自动识别

  • Java毕业设计-SpringBoot+Vue的班级综合测评管理系统(附源码、数据库、教程).zip

    Java 项目, Java 毕业设计,Java 课程设计,基于 SpringBoot 开发的,含有代码注释,新手也可看懂。毕业设计、期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。 包含:项目源码、数据库脚本、软件工具等,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行! 1. 技术组成 前端:html、javascript、Vue 后台框架:SpringBoot 开发环境:idea 数据库:MySql(建议用 5.7 版本,8.0 有时候会有坑) 数据库工具:navicat 部署环境:Tomcat(建议用 7.x 或者 8.x 版本), maven 2. 部署 如果部署有疑问的话,可以找我咨询 Java工具包下载地址: https://pan.quark.cn/s/eb24351ebac4 后台路径地址:localhost:8080/项目名称/admin/dist/index.html 前台路径地址:localhost:8080/项目名称/front/index.html (无前台不需要输入)

  • springboot大学生体质测试管理系统--论文.zip

    ava项目springboot基于springboot的课程设计,包含源码+数据库+毕业论文

Global site tag (gtag.js) - Google Analytics