`
fixopen
  • 浏览: 84328 次
文章分类
社区版块
存档分类
最新评论

软件工程、代码注释以及其他

阅读更多
自从1970年NATO会议以后,软件工程这个词就正式进入了软件开发领域,并且占据了越来越重要的地位。不可否认,软件工程确实为软件开发带来了一些作用,但是软件工程的缺陷也是很明显的。其中涉及到好几个方面的核心问题,现在暂时无法解决。
第一个问题是人的问题。
人不是机器,虽然有时候经过比较严格的训练在某些时间段可以表现得跟机器差不多,但毕竟不是真正的机器,这就是说,人的输入和输出并不是恒稳的。这是软件工程没有办法解决的硬伤。
第二个问题是软件度量问题。
这个问题到现在为止,可以说根本没有一个实质性的解决方案。关于软件的复杂度,软件开发的工作量,开发中的软件的完成度,软件的价值等等方面,从来没有一个可供哪怕仅仅是用来参考的模型。我知道有很多复杂性模型,但是他们都要求都软件很熟悉。这个要求就会转化为强制软件开发过程中必须有分析阶段和设计阶段,这是代价高昂的过程,后面我还会进一步提到。软件开发的工作量一般的认为是跟复杂度正相关的。但是,工作量还涉及到很多别的方面,要评估它是一个系统工程。完成度显见的也是与工作量和复杂性相关的,同时也与开发组织方式相关。现代的软件工程一般采用里程碑的方式来衡量工作完成度,我后面详细描述这方面的问题。
软件的创造性和不可重复性本质也是一个棘手的问题。
软件是迄今为止人类所能创造的最复杂的系统。这意味着,软件开发一般情况下需要一定程度的创造性,在很大程度上不是重复前人的经验,而是发现新的知识并且表达他们。就算不需要发现新的知识,我们也知道,只是的表达式很复杂的,为了让这些表达的知识真正具有价值,需要考量的因素很多,其中就牵扯到软件用户。不同的用户需要不同的知识表达,能够融入他们的知识体系中的知识表达。这就是创造性的。
现在开始描述里程碑的引入以及其固有的问题。
上面说到,为了度量软件工作的完成度,我们引入了里程碑的概念。
里程碑是这么一回事:
如果你驾车从西苑到西直门,在路途上的时候,你想知道你走了多少路程了,还差多少路程就到了,很简单,看看窗外的风景就知道了,为什么?你认识路呗。假设你要从西苑到密云水库,你不认识路,那你怎么知道已经走了多少了呢?哦,对了,路标,里程碑。就是它。看看里程碑上的里程数,并且你知道总里程数的话,那么恭喜你,你知道你走了多少了。
软件工程的里程碑也是借用这个概念,不过它不再是竖在路边标着里程的石柱,而是竖在概念世界中的某种象征物,一旦我们在现实的软件世界碰到了这种象征物,我们就知道我们已经走到某种程度了。
呵呵,我们通过上面的描述,似乎都能感觉到某些问题。是啊,这个象征物怎么出现的?项目的管理者怎么知道某种象征物一定会存在?甚至我们连我们的软件是什么(走多远)都不清楚呢?上面说到软件的创造性本质,也说到软件度量的困难,没有这些基础,我们怎么能奢望我们的里程碑是有意义的?
另外,里程碑的问题还在于它跟时间的结合上。我们上面说到,人是复杂的,输出是不恒定的,所以一旦标志物(里程碑)和时间结合起来,就意味着我们需要估计并确定人的输出。同时,上面说到的软件度量问题仍然造成障碍。
好的好的,我知道,里程碑仍然可能有意义,不是吗?我们通过长时间的分析问题,设计方案,我们对于问题已经有了相当程度地把握和直觉,所以我们可以小心翼翼的设置一些标志物了。是的,这个我是承认的。但是我们也要承认,很少有人能够真正准确的预测未来,就算问题我们已经很清楚了,我们也不能认为情况不会发生变化,事实上,在实现阶段发现问题并修正方案是很常见的情形。
所以,设定里程碑需要前期大量的投入,并且可能会随着情况的变化随时修正。
当然了,如果里程碑是完成这个极限,那么就只有一个里程碑了,跟没有是一样的,它省去了投入,也不用修正,但是不能用于指导我们的实践。
现在,你应该可以自己做决定了,是否需要和值得设定里程碑?
现在我们是不是进入死胡同了?有没有别的办法?
我觉得有,我提一个。
我们人类解决复杂问题的基本思路是两个:抽象和分而治之。
抽象是忽略掉我们暂时不想看到的,以便于我们能够从整体上把握。在软件开发的实践中,我们的实现必定要和无数的细节打交道,所以抽象不是我们的武器,那就只有分而治之了。分而治之是把一个大问题分解成几个关系相对较弱或者界限很清晰的几个小问题。对于小问题,我们还是有把握的。针对一个小问题,我们可以采用上面提到的极限时的里程碑,也就是完结。这样,我们就提出了一个可以设置好多里程碑(依赖于我们分成几个小问题了),并且能够检验我们任务的完成度的一个粗略但是相对低代价和好衡量的方法了。
其实这就是所谓的FDD,特征驱动开发。

关于代码注释。我这儿指的是写在代码中的,而不是其他别的。
先说一个我认为凌驾于任何软件开发原则之上的原则。DRY。不要重复你自己。不管是开闭原则(OCP)也罢,父子替换原则(LSP)也罢,甚至更高层次的高耦合低内聚原则也罢,统统都要向DRY让步。当然,这是我自己的观点。你完全可以不采纳。
其实,DRY是一个非常简单的原则,就是不要有重复。说的文绉绉一点,就是说要让你的决策集中化。当然,这两个说法并不是直接等价,而是推理等价的。
这个原则如果坚持的话,你会发现其实可以产生OCP LSP甚至高耦合低内聚等等原则相同的的效果。自己试验一下就知道了。
现在开始说代码注释。
代码注释是什么大家都很清楚,但代码注释应该干什么似乎没有共识。在重构的实践中,认为注释是坏气味,表示需要重构,我持有相同的观点。但是还有一些问题,那就是,究竟应不应该出现注释?任何注释都不应该出现?没有任何一种注释是必要的?甚至JavaDoc所要求的那些关于参数和返回值的基本注释?是的,它们是不必要的,它们的出现违反了DRY,你的代码应该比你的注释更清楚地说明他们的意义。而关于整体风格和习惯用法的信息,不应该出现在所有相关的 code中,而是出现在一个单独的文件中,由于它不是某些特定code相关的,而是所有code相关的,相信你也会觉得每一个code里面出现一份不爽,是的,如果这样又违反了DRY原则。那么,违反了DRY有什么后果呢?最基本的后果就是修改的重型化。由于你有重复,你必须在所有重复的地方修改,如果你有一处没有发觉,那么,不一致就发生了。代码和注释的不一致比没有注释要糟糕的多。有时候,我们确实需要注释,那我们也应该用一个工具生成他们。因为说到底它们跟代码是重复的。
哈哈,我听见有人这样子笑了。是啊,我为什么要让我的注释跟代码是重复的?我不能给出一些别的方面的跟代码无关的注释?是的。必然有点关系,但是关系要求多弱呢?如果我们read code的时候,突然出现了一段注释,而我们看的莫名其妙,我们是什么感受?作者在这儿夹这段注释的意义究竟“是什么”,为什么他要这样写?或许有一些东西我还没有理解?我还得仔细想想这究竟是什么意思?
另一个说法是注释可以给出一个摘要。对,我对摘要非常感兴趣,可我为什么要在代码中看到它们?如果我在阅读代码,我就是想知道所有的“细节”而不是摘要。所以为什么我们不把摘要放在单独的文件中?让我可以自然的顺流的读下来,而不是时时被一些细节绊倒?
还有的说法是注释给出一些关键实现的提示。这个很好,真得很好,它们是细节相关的,似乎应该放在代码中,可是,我们为什么不想想,为什么我们需要这些关键提示?为什么我们不能重构代码让代码给出这些提示?为什么我们要重复这些信息(一次是代码,一次是注释)?看看重构的书会打消你的这个想法的。
再有就是说,注释可以给出背景信息,我们知道,背景信息非常重要,可是在代码中表现不出来,所以我们用注释给出。呵呵,这个是一个非常值得反驳的例子,其实,这也是以前我对注释的作用的最基本的理解。我以前就这么做。让我们来看看为什么这有问题吧。
关于这个问题,最关键的是什么是背景信息?对于不同的人来说,所需要背景信息显然不同,你写的背景信息只对某类人或者某个人有效,那就是说,你的这些注释对大多数人来说是障碍和绊脚石,而不能提供理解的钥匙。

我再说说软件工程中流行的一些神话。
最出名的是那个关于错误发现时机的神话,它是这样说的,错误发现的越早,纠正它的代价越低,反之,发现的越晚,纠正它的代价越高。似乎能举出很多这样的例子。可它是错的。如果真的是这样,我们似乎被要求尽可能快的犯错误。这是荒谬的。
其实,对于错误发现的时机,强烈的依赖于两个因素,一个是人的因素,一个是问题的结构的因素,对于问题的结构,这个可以认为是客观的,不可改变的,可以改变的只有人自己了。对人自己来说,有两方面影响这个时机,一是自己的知识结构,一是解决问题采用的步骤。我们知道,这些问题要么是很难解决,要么是运气相关。所以很难把握。
我们再次回到错误发生后解决的代价这个问题上。
发生了错误,我们解决它,代价是什么?真的是时间相关的?这个结论无论正确与否,都不是直觉可得的。实际上,解决错误的代价是我们重新理解原来解决方案的代价。因为,我们发现了错误,那就是说,我们对问题有了新的看法和认识,我们有了新的解决方案,我们要理解原来的解决方案,然后给出改造的办法就解决了错误。这里面真正缠人的只有理解原来的解决方案。如果我们知道我们原来的解决方案,而且现在我们知道了错误,我们解决问题似乎并不需要费多少力气。既然如此,那么我们怎样加强我们的记忆,提高我们对原来解决方案的认识?重复是一个办法。这是一个不怎么消耗时间的脑力体操,你可以在很多情况下重新思考原来解决方案的整体或者某个细节。中国有句古话是:好记性不如烂笔头,如果你习惯于从纸面上获得信息,那么你就多做笔记,多复习。但是,请注意,这是与注释无关的,至少与我们上面说的那种形式的注释无关。
分享到:
评论

相关推荐

    测试软件-代码注释统计

    同时,开源的特性使得用户有机会深入学习和改进代码注释统计的方法,进一步提升软件工程的实践水平。在日常的开发工作中,我们应该积极使用此类工具,以保证代码的可读性、可维护性,从而提高软件项目的整体质量。

    源代码注释删除工具

    源代码注释删除工具是一种专门用于保护软件源代码安全的应用程序。在软件开发过程中,注释是用来解释代码功能、逻辑和设计意图的重要部分,但对于非授权的人员,这些注释可能泄露关键信息,使得他们能更容易地理解和...

    VB代码注释器

    良好的代码注释是软件工程中的重要环节,它可以帮助其他开发者理解代码的功能和意图,同时也能在后期维护时为自己的工作提供便利。 关于如何安装和使用VB代码注释器,压缩包内包含的详细使用说明会指导你完成整个...

    代码规模统计,可以统计代码行、注释行、代码注释公共行。软件工程大作业

    本项目名为“代码规模统计”,是针对软件工程课程的一次大作业,主要功能是统计代码行数、注释行数、代码与注释共行的公共部分以及空行数。这个工具特别之处在于它可以处理多个文件和文件夹,并且提供了文件类型筛选...

    pb 优化代码 注释工具

    代码注释在软件开发中起着至关重要的作用。它可以使代码更加清晰易懂,方便团队协作和后期维护。一个良好的注释工具能够快速地对代码进行批注,节省开发者手动添加注释的时间。对于PowerBuilder开发者来说,这样的...

    软件工程代码

    "软件工程代码"这个主题涵盖了软件开发过程中的编码规范、版本控制、测试、调试以及维护等多个环节。这里我们将深入探讨这些方面,结合描述中的“大连理工离线作业\2.27日 56355作业3个完稿”,我们可以推断这是一个...

    清除Java代码注释

    当然,对于非程序员或者希望快速操作的用户,也有一些第三方工具可以实现批量清除Java代码注释,例如Java Comment Remover等。这些工具通常具有用户友好的界面,只需选择目标文件或目录,然后点击“清除注释”按钮...

    软件工程全套文档

    在IT行业中,软件工程是一门综合性的学科,它涵盖了软件的整个生命周期,包括需求分析、设计、编码、测试以及维护等多个阶段。"软件工程全套文档"这个资源为开发者和项目管理者提供了一整套完整的文档模版,以确保...

    PFC3D参考程序流代码注释_PFC_pfc3d_

    **程序流代码注释**在软件开发中至关重要,它有助于理解代码的功能和执行流程。注释可以提供关于函数、变量、循环和条件语句的详细解释,使得其他开发者能够快速地了解代码的工作原理,提高代码的可读性和可维护性。...

    C#见缝插针工程 代码注释详细 拿走吧

    9. **代码注释**:项目强调代码注释详细,良好的注释可以帮助理解和维护代码,提高代码可读性。学习如何书写规范、清晰的注释是每个程序员应该掌握的技能。 通过研究这个【C#见缝插针工程】,开发者不仅可以提升C#...

    iOS android 有效代码 注释率 工具

    在软件开发过程中,代码质量和可维护性是至关重要的因素,其中注释率和有效代码量是衡量这些因素的重要指标。本文将深入探讨如何利用给定的工具来统计iOS和Android项目中的注释率以及有效代码行数。 首先,我们要...

    阿里软件工程师代码规范

    《阿里软件工程师代码规范》是Java软件开发领域中一份重要的指导文档,旨在提高代码质量、增强可读性、促进团队协作以及确保项目可持续发展。这份规范涵盖了命名规则、注释标准、类与对象设计、异常处理、并发控制等...

    过滤代码工程文件注释

    在软件开发过程中,代码工程文件的管理是至关重要的。标题提到的"过滤代码工程文件注释"是一项常见的优化策略,其主要目的是减少代码占用的空间,尤其是对于需要打包发布的项目而言,注释的去除可以显著减小文件大小...

    软件工程作业项目(银行账户系统)完整源代码以及报告文档

    这个系统是作为软件工程课程的作业项目,旨在让学生们实践软件开发的全过程,包括需求分析、设计、编码、测试以及文档编写。下面我们将详细讲解其中涉及的关键知识点。 首先,"银行账户系统"是一个典型的业务管理...

    软件工程 教辅+部分答案

    其他资料可能包括案例研究、习题解答等,对深入理解软件工程概念非常有帮助。 通过阅读英文版教辅和答案,学习者不仅可以提升专业英语能力,还能加深对软件工程原理和实践的理解,为未来的软件开发职业生涯奠定坚实...

    软件工程 PPT 高级软件工程讲义

    良好的文档和代码注释对于后期的维护工作至关重要。 总结来说,《软件工程 PPT 高级软件工程讲义》涵盖了软件工程的全貌,从理论到实践,从需求到维护,是学习和提升软件工程技能的宝贵资源。通过阅读和研究这些PPT...

    软件工程编码规范

    软件工程编码规范的内容包括命名规范、编码规范、注释规范、错误处理规范等。这些规范可以帮助开发者编写高质量的代码,提高代码的可读性和可维护性。 4. 命名规范 命名规范是软件工程编码规范的重要组成部分。...

    东北大学软件工程期末复习题ssd9

    9. **软件工程规范**:包括代码风格、文档编写标准、注释规范等,提升代码可读性和团队协作效率。 10. **软件维护与演化**:软件的后期更新、修复、优化和扩展能力的考虑。 复习这些内容时,学生不仅需要理解理论...

    软件工程模拟题

    【软件工程模拟题】 在软件工程的学习过程中,模拟题是一种非常有效的复习工具,它可以帮助学生理解和掌握课程中的关键概念、方法和技术。这份“软件工程概论期末考试”的模拟题集全面覆盖了软件工程的主要知识点,...

    东北大学计算机学院软件工程实验

    软件工程实验是该课程的重要组成部分,通过实践性学习,学生能够深入理解软件生命周期的各个阶段,包括需求分析、设计、编码、测试以及维护。 实验一:需求获取与分析 在这一阶段,学生们会学习如何从用户和利益...

Global site tag (gtag.js) - Google Analytics