当前访客身份:游客 [ 登录  | 注册加入尚学堂]
启用新域名sxt.cn
新闻资讯

写软件不是造汽车

helloworld 发表于 2年前  | 评论(0 )| 阅读次数(521 )|   0 人收藏此文章,   我要收藏

写软件和做其他事情是不一样的。当我们制造别的东西的时候——像汽车、玩具、椅子、画作、甚至包括数字产品如平面图片和3D模型——我们做出来的成 品就是最终的结果。而开发软件则不是,我们做出来的产品永远不可能有最终的结果——我们需要向计算机解释如何根据任意的输入来输出任意可能的结果。

写软件不像造汽车,或者可以这么说,它更像是建立一个汽车装配生产线。

我们很容易了解汽车制造的设计观念,产品设计师只要拿着一张设计图纸,说一声“照这个做”,然后工程师们就可以开工了,开始制造一个看上去真实存在的东西。

假设我们的产品设计师需要给一个网站开发一个用户资料管理系统,一个简单而完美的设计也许就是在布局好的页面中放置几个占位符文本,用来显示用户 名、用户头像和一些基础资料数据。然而,这仅仅是开发软件过程中的假设阶段,实际操作很复杂。比如用户如何编辑这些字段?窗口页面太窄了怎么办?页面如何 在各种屏幕的阅读器中展示不错的效果?产品设计师只是假设了一些理想状况下的页面,但是开发者却需要将每一种可能遇到的情况都考虑到。

回到刚才打的“汽车装配生产线”这个比喻,产品设计师提出一些看上去很简单的需求,就像“可以把驾驶室的车门颜色由红色替换成蓝色吗?”这样的需 求。这是一种误导——做一辆红色车门的汽车看起来很简单,但实践起来却非常困难——我们需要调整生产线上的配色系统以便让其支持喷刷多种颜色的油漆,这就 要增加一些局部喷色的逻辑,并且需要增加配置选项以允许人们在生产线上可以选择需要喷刷的油漆颜色。还有就是需要购买一些新的喷漆嘴,因为红漆比蓝漆流动 更快一些。而且需要安排更好的健康保险,因为一旦销售人员知道你制造的汽车只有一扇门是红色的,他们会疯狂地扔东西。

在软件开发中也会发生类似的事情。“嘿,这个用户管理系统看起来很不错,可以在用户生日的时候发送一条祝福消息吗?”于是你又接收到了一条看似简单的需求。

当你在开发软件的时候,你并不是在构建用户管理系统中的一个页面,而是在创建一条装配生产线,它由一堆的零部件组成,而且可以每次生成正确的用户管理页面。

分享到:0
关注微信,跟着我们扩展技术视野。每天推送IT新技术文章,每周聚焦一门新技术。微信二维码如下:
微信公众账号:尚学堂(微信号:bjsxt-java)
声明:博客文章版权属于原创作者,受法律保护。如果侵犯了您的权利,请联系管理员,我们将及时删除!
(邮箱:webmaster#sxt.cn(#换为@))
北京总部地址:北京市海淀区西三旗桥东建材城西路85号神州科技园B座三层尚学堂 咨询电话:400-009-1906 010-56233821
Copyright 2007-2015 北京尚学堂科技有限公司 京ICP备13018289号-1 京公网安备11010802015183