`
saybody
  • 浏览: 903118 次
  • 性别: Icon_minigender_2
  • 来自: 西安
文章分类
社区版块
存档分类
最新评论

谈谈编程(2) 软件开发中的方法论

阅读更多

1 项目管理的方法论

1.1 方法论

方法论的英文为Methodology,编程的方法论应该是指软件开发的一整套方法、过程、规则、实践、技术。不过我们一般提到的方法论都偏重于项目、过程和人员的管理。

《Agile Software Development》的作者Alistair Cockburn提出方法论具有以下要素:角色、个性、技能、团队、技术、活动、过程、产品、里程碑、标准、质量、工具、团队价值,它们的关系可以用一幅图来表示:

虽然将这幅图贴在这里,事实上我不了解这些要素及其关系的确切定义,对于这些不能精确描述的东西,我接受起来比较困难。

其实,项目管理的核心是沟通和反馈。只要能够保证良好的沟通和即时的反馈,开发团队即使并没有采用先进的方法论,一样可以成功。从另一个角度说,过程和工件能辅助,但不能保证开发人员、项目经理和客户的良好交流。

1.2 重型方法

有的方法论规定了大量的中间文档和复杂的过程管理。那些中间文档被称为artifact,或工件。需要大量artifact和软件开发方法被称作重型(Heavy Weight)方法。

这些复杂的方法来源于恐惧。

在中大型的项目中,项目经理往往远离代码,他们无法有效的了解目前的工程的进度、质量、成本等因素。为了克服未知的恐惧感,项目经理制定了大量的中间管理方法,希望能够控制整个项目,最典型的莫过于要求开发人员频繁地递交各种报告。重型方法中的基本假设是过程(及各种artifact)比个人可靠。

虽然很多轻型方法都将重型方法作为反面例子,但对于大多数大型项目,重型方法是管理所必需的。

1.3 轻型方法

为了解决重型方法存在的问题,业界出现了很多轻型(Light Weight)方法论。提出这些方法论的部分作者结成了一个联盟:敏捷软件开发。他们还有一个宣言:

  • Individuals and interactions over processes and tools.
  • Working software over comprehensive documentation.
  • Customer collaboration over contract negotiation.
  • Responding to change over following a plan.

在这些宣言后面还有很多原则。概括起来主要是:尊重个人,强调沟通和反馈,与客户紧密合作,保持设计的简单性等等。敏捷方法在重型方法论和无管理状态之间寻求一个平衡点,希望用低成本的管理活动带来最大的产出。

2 编程的方法论

作为程序员,我更感兴趣的是可以指导编程的方法论。

2.1 测试驱动开发

2.1.1 未谋进,先谋退

开始一件事情之前,必须先明确什么时候可以停止。什么“止于至善”,在编程工作中可以一脚踢开。我们必须明确要做什么,做到什么样子就算完成了。

怎样才算明确呢?最理想的方法是先写一个测试程序,然后再编写代码,让测试通过。测试程序规定了停止的必要条件。

测试程序是针对接口编写的。要写出测试程序,必须先定义好接口,然后针对接口编程。测试程序同时示范了接口的使用。

如果有一个运行很方便的测试程序,我们在维护代码时,就放心得多。可以经常跑一跑,测试一下,以保证测试要求的功能还没有被破坏。相反,如果没有测试程序,我在修改代码的bug时,心里就很不踏实,因为我不清楚我的修改是否会引入新的bug。

2.1.2 保持可运行,可调试的状态

“先写测试程序”适合没有UI,功能相对简单的模块。对于功能复杂的软件系统,需要测试的方面很多,测试时间很长,在开发前就建立一个比较全面的测试,并且随时使用,有时是不可能的。

但我们至少应该保证:写任何程序,都要尽量保持在可运行、可调试的状态。即使要为此写一些额外的程序,都是值得的。在不能运行的情况下,编写大量代码是不可思议的事情。

2.1.3 可测试性

IC设计上有一个“Design For Test”的说法,即IC的设计中必须要考虑到如何测试,留好测试的接口。软件开发也是一样的,我们写每段代码,都要考虑一下这段代码是否可以测试,为了保证可测试性,必要的时候可以修改设计。

2.2 重构

《重构》这本书内容朴实、但对我个人影响很大。在了解“两顶帽子”和“小步前进”的方法后,我敢于修改任何代码,甚至是我不熟悉底层逻辑的代码。

2.2.1 两顶帽子

我们有两顶帽子:一顶是不改变功能的前提下,改善现有现有程序的设计;另一顶是增加新的功能,以适应需求变化。我们在任意阶段,应该只戴一顶帽子,绝对不能同时戴两顶帽子。

在增加新功能的时候,往往需要先改进现有的代码结构,使之能更好地适应变化。如果功能有较大变动,我们应该将这变动分解成尽可能小的步骤,并让改进代码和新增功能的小步骤交替进行。将原有代码平滑地演变到新代码,既增加了功能,又改善原有代码的设计。

重构的正式定义应该是“在代码写好之后改进它的设计”。但对我而言,重构的思想已经融入了我的开发过程。在开发中,我同样按照“两顶帽子”和“小步前进”的方针平滑地演变代码,从无到有,逐步完善。

2.2.2 代码的坏味道

重构的对象是消除“代码的坏味道”,保持新鲜、健康的代码。《重构》中列举了一些典型的坏味道,例如重复代码、太长的函数、太长的参数列等等。

2.2.3 设计和重构

存在这么一种说法:“设计不再是一切动作的前提,而是在整个开发过程中逐渐浮现出来”的。

事实上,在没有任何软件工程理论的时代,编程基本上是写到哪儿算哪儿。历史是螺旋上升的,在投影上很接近的两个点在铅垂线方向上是处于不同高度的。

重构是要纠正过度设计的倾向,告诉程序员:即使开始的设计有缺陷,也没关系,更不要僵化地保持,我们可以重构代码,平滑地修改原有设计。这并不是说前期设计不重要。

“设计是在整个开发过程中逐渐浮现出来”,这是在说随着开发的深入,我们会对很多问题考虑地更加清楚。在必要的时候,我们应该用重构的方法灵活地改变设计,适应变化。

分享到:
评论

相关推荐

    谈谈软件开发的那些事儿

    职责驱动设计(DDD)和极限编程(XP)等方法论提倡紧密协作和快速反馈,以提升开发效率和软件质量。 总结来说,软件开发是一个不断发展和进化的领域。从早期的简单系统到现在的复杂企业级应用,开发者需要掌握更多...

    软件方法论

    在IT行业中,软件方法论是指导软件开发过程的一系列理论和实践原则。这些方法论旨在提高效率、质量、可维护性和可扩展性,确保软件项目能够成功实施并满足用户需求。下面将详细探讨标题和描述中提及的几个关键概念:...

    十年总结 靳雄飞 程序员编程经验

    **软件开发方法论**:《十年总结(十二):软件开发思想之争—RUP VS XP》中,对比了两种主流的软件开发方法——Rational Unified Process (RUP) 和 Extreme Programming (XP),并对它们各自的优缺点进行了深入分析...

    上传一本书(Agile_Java英文版)

    敏捷开发是一种以人为本、迭代、增量的软件开发方法,其核心原则是通过频繁交付有价值的软件,与客户保持密切合作,并欢迎需求变更。敏捷宣言包含了四个价值观:个体和互动高于流程和工具,可工作的软件高于详尽的...

    软件测试工程师真题+模拟题

    这需要深厚的编程知识,对软件开发生命周期的理解,以及强大的问题解决能力。 在资源包中提到的"2010软件测试工程师"真题,这部分内容可能包括了理论题和实践题两部分。理论题可能涵盖软件工程、质量保证、测试方法...

    开科合集.rar

    软件开发流程和方法论也是开科合集的重要组成部分。敏捷开发、Scrum、Kanban、DevOps等概念可能有所涉及,这些现代开发模式强调快速迭代、持续集成和自动化测试,以提高软件质量和效率。 此外,压缩包可能还包含...

    《Linux系统管理技术》期末考核题目.docx

    学生需要结合所学的《Linux系统管理技术》课程的相关知识和软件工程的专业特性,谈谈自己对Linux下的软件开发的认识、体会。 例如,学生可以撰写一篇小论文,总结自己对Linux下的软件开发的认识、体会,例如: ...

    课程设计.rar

    这需要了解测试方法论,如黑盒测试、白盒测试,以及如何使用调试工具。 5. **文档编写**:项目报告、用户手册等文档的编写,有助于其他人理解项目。a.txt可能就是一份初步的项目报告或设计文档,包含了项目介绍、...

    程序设计经验杂谈-给予帮助

    测试驱动开发(TDD)和持续集成(CI)等方法论,可以确保代码的质量和稳定性。编写文档和制定规范,可以保证团队之间的沟通无阻。 总之,“程序设计经验杂谈”中的内容可能会涵盖这些方面,以及更多实用的技巧和经验...

    单片机的相关论文很有用的

    2. **PROTEUS软件仿真与KEIL的单片机系统设计**:PROTEUS是一款强大的电子电路仿真软件,常用于单片机系统的设计和调试。KEIL则是一款流行的单片机开发工具,支持C语言编程。这两者的结合使用可以大大提高单片机开发...

    领域驱动设计C# 2008实现问题.设计.解决方案

    领域驱动设计(Domain-Driven Design,简称DDD)是一种软件开发方法论,旨在通过紧密合作将业务专家和开发人员的知识融合,以解决复杂领域的业务问题。在C# 2008这一特定编程环境下,实现DDD可以帮助开发人员创建...

    计算机毕业设计 10个数据结构课程设计实例二叉树建立遍历冒泡排序 C&C++源代码+开发文档说明 软件/插件 范文 模板

    软件/插件部分可能包含了一些辅助工具或环境,帮助你在实际开发过程中调试和测试代码。范文和模板则提供了一个参考框架,让你更好地组织和展示你的工作。 通过这个项目,你不仅可以掌握数据结构和算法的基本知识,...

    毕业论文设计-IT计算机-VBIC卡管理系统(源代码+论文+翻译+答辩PPT).zip

    首先,我们来谈谈VB编程语言。VB,全称Visual Basic,是由Microsoft开发的一种面向对象的编程语言。它以其直观的图形用户界面和相对简单的语法而闻名,非常适合初学者和快速开发原型。在这个管理系统中,VB可能被...

    浙大模板 非常经典浙大模板 非常经典

    浙江大学,作为中国知名的高等...学习和掌握这些知识,不仅可以提升在编程竞赛中的表现,也能对日常的软件开发工作带来很大帮助。因此,无论是对于参赛者还是普通的程序员,研究和运用浙大模板都是提升技能的有效途径。

    程序员成长路线图:从入门到优秀

    - **软件工程概念:**了解软件开发流程、版本控制工具(如Git)、项目管理方法论(如敏捷开发)等。 **技能培养:** - **逻辑思维能力:**编程本质上是对问题的抽象化处理,强大的逻辑思维能力可以帮助程序员更好...

    Agile Java学习笔记【二】

    敏捷开发是一种以人为本、迭代、逐步发展的软件开发方法论,强调快速响应变化,提高软件质量与团队协作效率。 首先,敏捷开发的核心理念是“人高于过程和技术”。它提倡通过短周期的迭代,持续交付可工作的软件,...

    毕业设计哦

    这部分通常涉及到软件开发、硬件设计、实验研究等具体项目。在进行项目设计时,应注意以下几点: 1. **需求分析**:明确项目的目标和功能,理解用户需求,编写需求规格说明书。 2. **系统设计**:根据需求分析,...

    menet 62ecb60 分支 源码

    6. **错误修复**:任何软件开发过程都伴随着错误的修复,Menet 62ecb60分支可能修复了一些已知问题,提升整体稳定性。 为了安装和理解Menet 62ecb60分支,根据描述中的提示,我们需要按照`readme.md`文件中的步骤...

    笔记

    敏捷开发、Scrum框架、持续集成/持续部署(CI/CD)等方法论在现代软件开发中广泛应用,它们强调迭代开发和快速反馈,以提高效率和产品质量。 在"NOTES-master"这个文件名中,"master"通常代表主要的或主分支,可能...

Global site tag (gtag.js) - Google Analytics