软件随想录(local.joelonsoftware.com/wiki)-2000年10月02日 无痛功能规格 - 第一篇: 何必麻烦呢? - Painless Functional Specific

本文主要是介绍软件随想录(local.joelonsoftware.com/wiki)-2000年10月02日 无痛功能规格 - 第一篇: 何必麻烦呢? - Painless Functional Specific,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2000年10月02日 无痛功能规格 - 第一篇: 何必麻烦呢? - Painless Functional Specifications. Part 1: Why Bother?

 

The Joel on Software Translation Project:无痛功能规格(一)

From The Joel on Software Translation Project

Jump to: navigation, search

无痛功能规格 - 第一篇:何必麻烦呢?

作者:周思博 (Joel Spolsky)
译:Paul May 梅普华
编辑:Jeff Wang 王家麒
October 2, 2000
A part of Joel on Software, http://www.joelonsoftware.com


当约耳试验刚发表时,读者反映说执行上最困难的一点就是写规格。看起来规格就像用牙线:大家都知道应该要,却没有人真的在做。

为什么大家不写规格呢?有人声称跳过写规格这个步骤可以节省时间。讲得好像写规格像是什么奢侈品,只有NASA太空梭工程师或为大保险公司工作的人才能做。胡说八道。不写规格是软件项目中一个最大且不必要的风险。这就像只在背上挂件衣服就妄想飞越摩哈维沙漠一样的愚惷。那些不订规格直接写程序的程序员和软件工程师都会自认是神枪手,可以朝背后开枪。才怪。他们根本没有生产力。他们写出烂程序并做出低劣的产品,而且还让项目承受完全可以避免的极大风险。

Main_Beach_Lifeguards_2.jpg

我认为所有重要的项目(写程序时间超过一周或一个以上的程序员)都一样,如果没有规格,绝对会耗时更久并且写出品质低劣的程序。理由如下。

规格最重要的功能是要设计程序。即使你是自己一个人写好所有的程序,而且写了规格也只是自己在看,写规格这个动作(详细描述程序运作)还是能迫使你实际设计程序。

让我们看看分属两家公司的两名虚构程序员。速食香蕉软件的史快手从来不写规格。「规格?我们才不要讨厌的规格!」而好脾气软件公司的罗杰先生则在规格确定前绝对不写程序。他们只是我众多虚构朋友中的两位。

史快手和罗杰先生有个相同点:他们都负责自家产品2.0版的向后相容事宜。

史快手决定,提供向后相容的最佳方法就是写一个转换器,把1.0版的文件转成2.0版文件。她开始打程序,喀嗒喀嗒,硬盘转呀转,鸡飞狗跳。大约两周后弄出一个还不错的转换器。不过史快手的客户不太高兴。史快手的程序等于强迫全公司一次升级成新版本。史快手最大的客户Nanner Splits无限公司拒绝购买新软件。他们要确定2.0版软件能不经转换使用1.0版文件。史快手决定写一个回溯转换器并挂在「存档」功能內。这就有点复杂了,在使用2.0版的功能时似乎一切正常,不过等要把文件存成1.0格式时就有问题了。你会发现前半小时用的新功能都无法以旧的文件格式储存。所以回溯转换器又写了两周,而且也不是很好用。这样子4周就过去了

而好脾气软件公司的罗杰先生是那种一切照规矩的人,没拿到规格前是绝对不写程序的。他花了20分钟设计出和史快手一样的向后相容功能,并且写出大意如下的规格:

    1. 如果打开的文件是由旧版产品所建立的,就把文件转成新格式。

把规格先拿给客户看看,客户说话了「等一下!我们不想让全公司都升级!」所以罗杰先生再想想后把规格改成:

    1. 如果打开的文件是由旧版产品所建立的,就把文件在内存內转成新格式。等要储存这个文件时,使用者可以选择存回旧格式。

这样又用了20分钟。

罗杰先生的老板是个面向对象狂。他看看这份规格,觉得有点问题并且建议用另一种架构。

    1. 把程序重组成使用两组介面:V1和V2。V1包含所有版本一的功能,而V2则是继承V1并加上所有新功能。这样V1::Save可以处理向后相容事宜而V2::Save可以储存所有新东西。如果你打开V1文件后使用到V2的功能,程序可以马上警告你,你必须转换成新文件格式或放弃使用新功能。

又20分钟去了。

罗杰先生不太高兴。因为重组程序要花3周而不是他原先估的2周!不过的确优雅地解决了客户所有的问题,所以他还是回去照做了。

罗杰先生所花的时间总共是3周加1小时。史快手则花了4周,不过史快手的程序没那么好。

这个故事告诉我们,只要举的例子够怪,什么事都可以证明。对不起,刚才是开玩笑的,我不是这个意思。这个故事真正要说的是,当你以人用的语言设计产品时,只需要花几分钟就能考虑多种可能并且修订及改进自己的设计。没有人会觉得在文书处理器里删掉一段有啥大不了的。不过当你用程序语言设计产品时,反覆设计就得花上好几周了。更糟糕的是,某段程序可能只花程序员2周就写出来,可是他会一直死抱著那段程序,不管程序错得多么离谱。虽然史快手的程序并非最佳的架构,可是不管她老板或客户说什么,都无法说服她把那段漂亮的转换程序丟掉。结果最终的产品很容易变成最初设计和错误设计以及理想设计间的妥协。它是「我们所能做到的最佳设计,因为这些程序都写好了,而我们又捨不得把写好的程序丟掉重写」。如果光是「我们所能做到的最佳设计」,没有后面那些废话会更好。

Upper_West_Side_Restaurant.jpg

所以这就是写规格的天字第一号理由。天字第二号是节省沟通时间。当你有写规格时,对于程序应有的作用只需要讲解一次。团队里其他人只要读规格就好了。品保人员读了规格就知道程序的动作同时也知道如何测试。行销人员读了规格就能写出暧昧的资料,放在网站上宣传尚未出现的产品。事业开发人员没好好读规格却在幻想,以为产品能治疗禿头肿瘤还有毒瘾,不过这样能吸引投资者,所以没啥关系。开发人员读了规格就知道要怎样写程序。客户读规格则是要确定开发人员正在制作他们想买的产品。技术作者读了规格才能写出好的手册(然后被遗失或丟掉,不过这是另一个故事)。经理也读规格,才能让自己好像知道经营会议的內容。如此类推。

这所有的沟通在没有规格时还是会发生,因为这都是必要的,不过这时的沟通都是特别安排的。品保人员无论如何都得玩这个程序,看到有任何不对劲就会再度中断程序人员,并且问另一个程序应该怎么动的蠢问题。这不只会毀掉程序人员的生产力,而且程序人员也习惯照自己程序的写法回答问题,而不会回答「正确的答案」。结果品保人员实际上是用程序来检验程序,而非以设计来检验程序,而后者应该会好一点吧。

当你没有规格时,可怜的技术作者会遇到很好笑的事(以极悲惨的方式)。技术作者通常没有中断程序人员的特权。在很多公司中,如果技术作者习惯中断程序人员问些程序运作上的问题,程序人员会找经理告状,说这些该死的作者让他们什么事都做不了,他们闪远一点。经理为了想提升生产力,就禁止技术作者不要浪费程序人员宝贵的时间。这种公司很容易分辨,因为它们的说明档和手册里讲的没比画面上多多少。当你在画面上看到以下的讯息

    1. 你要启动LRF-1914支持吗?

...当你点选「说明」就会看到一段叫人哭笑不得的內容

    1. 允许你选择LRF-1914支持(预设值)或无LRF-1914支持。如果你需要LRF-1914支持,点选「是」或按「Y」。如果不需要LRF-1914支持,点选「否」或按「N」。

嗯,谢了。很显然技术作者试图掩饰他们不知道LRF-1914支持是啥的事实。他们不能问程序人员,因为(a)他们太害羞了,或是(b)程序人员在海得拉巴(印度)而他们在伦敦,或者(c)管理阶层禁止他们中断程序人员或是其他各种数不清的企业弊病,不过根本的问题在于没有规格

写规格的天字第三号理由就是没有详细规格就无法订出日程。有些场合没有日程是可以的,例如你打算花14年研究的博士论文,或打算写下一版等好了就会推出的毀灭公爵游戏。不过几乎所有真实的事业都必须知道事情需要多久完成,因为开发产品是要花的。你不可能不知道价钱就买牛仔裤,那么一个负责的企业怎么能不知道要多少还有要多少钱,就决定是否制作某个产品呢?想多了解日程安排,请参考无痛软件日程。

有个很糟糕的常见错误,就是对某个项目的设计争论不休,结果永远无法排除争议。Windows 2000的首度开发人员Brian Valentine就有句名言「10分钟內给你决定,否则下一个免费」(译注:美国著名的披萨连锁店达美乐有一句广告标语「30分钟內送达,否则下一个免费」。同样的,Brian会在10分钟內决定,否则会免费给你下一个决定,不过要老板下决定本来就不用付钱给你的,不是吗?)

在很多的程序开发组织中,每次出现设计争议总是没有人愿意作出决策(通常都是因为政治理由)。所以程序人员只去做那些没有争议的项目。等时间消逝而所有困难的决定都会压到最后才决定。这些项目很可能会失败。如果你针对某项新技术开了家新公司,却注意到公司有结构性问题无法作出决策,你最好关门大吉把钱退还给投资者。因为你永远都无法推出产品。

写规格是处理这些烦人设计决策的好方法,这些问题有大有小,不过没写规格就看不到。即使很小的决策问题也可以写规格搞定。举例来说,如果你正在建一个会员网站,你们可能都会同意,当使用者忘记密码时应该发信告知密码。很好,不过对写程序来说还不够。要把程序写出来得知道邮件中实际使用的文句。大部份公司都不认为程序人员能撰写使用者实际接触的文句(而且通常都有很好的理由)。所以会要求行销人员或公关或是其他文学素养好的人决定讯息的文句內容。「王大明先生,这是阁下忘记的密码。希望阁下往后能小心一点。」当你强迫自己写出一份良好而完整的规格时(我很快就会详述这一点),就会注意到这所有的项目并且把它解决,或者至少标示出来以便修正。

好了。我们现在应该都能同意。规格是一切的根本。我怀疑大部份的人是否懂这一点,另外我讲的虽然有趣,却不知是否真能让你学到新东西。那么为什么人们写规格呢?绝不是省时间,因为根本不会省,而且我认为大多数程序员都知道(在大部份组织中,唯一存在的「规格」都是断简残篇,是程序员写好程序解说某该死功能第三百遍,用记事本打出来的一页文字文件。

Lincoln_Center_Duck.jpg

我认为真正原因是多数人都不喜欢写东西。瞪著空白的屏幕会让人感觉极度地沮丧。我个人克服写作恐惧的方法是去学校参加写作课,一星期写3到5页的短文。写作就像肌肉一样,写得愈多就愈能写。如果你必须写规格又写不出来,开个期刊定讯,建一个weblog,上个创作写作课程,或是写封信给亲戚或四年未联络的大学室友。任何把文字填到纸上的活动都能增进你写规格的技巧。如果你是个软件开发经理而该写规格的人写不出来,把他送到山里面上两周创作写作课吧。

如果你未曾在一家有写功能规格的公司做过,可能会没看过功能规格。我会在本系列的下一篇中展示一篇简短的规格范例供你参考,另外我们也会讨论一份好的规格必须具备的元素。继续看!

这些网页的內容为表达个人意见。
All contents Copyright 1999-2002 by Joel Spolsky。All Rights Reserved。

 

这篇关于软件随想录(local.joelonsoftware.com/wiki)-2000年10月02日 无痛功能规格 - 第一篇: 何必麻烦呢? - Painless Functional Specific的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/885335

相关文章

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

如何评价Ubuntu 24.04 LTS? Ubuntu 24.04 LTS新功能亮点和重要变化

《如何评价Ubuntu24.04LTS?Ubuntu24.04LTS新功能亮点和重要变化》Ubuntu24.04LTS即将发布,带来一系列提升用户体验的显著功能,本文深入探讨了该版本的亮... Ubuntu 24.04 LTS,代号 Noble NumBAT,正式发布下载!如果你在使用 Ubuntu 23.

Ubuntu 怎么启用 Universe 和 Multiverse 软件源?

《Ubuntu怎么启用Universe和Multiverse软件源?》在Ubuntu中,软件源是用于获取和安装软件的服务器,通过设置和管理软件源,您可以确保系统能够从可靠的来源获取最新的软件... Ubuntu 是一款广受认可且声誉良好的开源操作系统,允许用户通过其庞大的软件包来定制和增强计算体验。这些软件

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

通过C#和RTSPClient实现简易音视频解码功能

《通过C#和RTSPClient实现简易音视频解码功能》在多媒体应用中,实时传输协议(RTSP)用于流媒体服务,特别是音视频监控系统,通过C#和RTSPClient库,可以轻松实现简易的音视... 目录前言正文关键特性解决方案实现步骤示例代码总结最后前言在多媒体应用中,实时传输协议(RTSP)用于流媒体服

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

基于Qt实现系统主题感知功能

《基于Qt实现系统主题感知功能》在现代桌面应用程序开发中,系统主题感知是一项重要的功能,它使得应用程序能够根据用户的系统主题设置(如深色模式或浅色模式)自动调整其外观,Qt作为一个跨平台的C++图形用... 目录【正文开始】一、使用效果二、系统主题感知助手类(SystemThemeHelper)三、实现细节