`
saybody
  • 浏览: 913470 次
  • 性别: 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++源代码+开发文档说明 软件/插件 范文 模板

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

    100个经典算法.docx

    学习和掌握这些算法,不仅能够加深我们对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