我对软件工程的理解

1 引言

从事软件行业这么年,写了10年代码,又从事了多年的项目产品方面的工作,一些每天用到的软件工程的方法,虽然天天都在用但一些概念总感觉似是而非,正好借假期的时间,好好整理下,以供自己或他人进行参考使用。

2 相关名词解释

2.1 软件工程

软件工程是应用计算机科学、数学、逻辑学及管理科学等原理,开发软件的工程(来源于《计算机科学技术百科全书》的定义),我个人认为这个定义还是准确和好理解一些。另外软件工程也是高校的一个计算机类专业。

1968年在德国举行的NATO软件工程会议上,为应对"软件危机"的挑战,提出了"软件工程"的术语。这个时期有代表性的软件工程定义是"为了经济地获得在真实机器上可靠工作的软件而制定和使用的合理工程原则和方法"。

2.2 瀑布方法(Waterfall Model)

瀑布方法是软件开发中最早出现的模型之一,早期主要用于开发大型软件系统。该模型采用线性进程,任务按照建立系统需求、系统设计、实现、测试和维护五个阶段依次完成。因此,该模型也被称为"线性软件开发模型"。

1970年温斯顿·罗伊斯(Winston Royce)提出了著名的"瀑布模型",直到80年代早期,它一直是被广泛采用的软件开发模型。

瀑布方法的核心思想是将软件开发过程划分为多个阶段,包括需求分析、设计、编码、测试等,每个阶段都有明确的输出和验证标准。这种方法强调了开发过程的线性顺序和阶段的独立性,便于管理和控制‌

2.3 敏捷方法

敏捷方法是一种从1990年代开始逐渐引起广泛关注的一些新型软件开发方法,是一种应对快速变化的需求的一种软件开发能力。敏捷开发(agile development)是一种以人为核心、迭代、循序渐进的开发方法。

2001年2月,17名软件开发人员聚在犹他州开会,讨论轻量级开发方法,意识到他们正在集体实践不同于经典瀑布方法的软件开发, 而且它们并非全部都在初创公司中。 他们提出了《 敏捷宣言》 ,记录了他们对现代软件开发过程应该如何运作的共同信念。

2.3.1 SCRUM迭代式增量软件开发过程

Scrum是迭代式增量软件开发过程,是敏捷方法论中的重要框架之一,通常用于敏捷软件开发。Scrum包括了一系列实践和预定义角色的过程骨架。

在1995年OOPSLA大会(为面向对象编程系统,语言以及应用程序举办的年度会议)上Sutherland和Schwaber(相识于1980年代早期)第一次向世人介绍了Scrum(两人在一个IBM项目合作,并做了更详尽的研究,于是Scrum诞生了),可当时,两个人的公司都还在做千年虫和各种重型开发方法咨询方面的业务呢。

2.3.2 XP极限编程

极限编程(ExtremeProgramming,简称XP)是一种软件工程方法学,是敏捷软件开发中可能是最富有成效的几种方法学之一。

由KentBeck在1996年提出的,如同其他敏捷方法学,极限编程和传统方法学的本质不同在于它更强调可适应性能性以及面临的困难。适用于小团队开发。

2.4 结构化方法

Structured Method,结构化方法是一种软件开发方法,一般利用图形表达用户需求,强调开发方法的结构合理性以及所开发软件的结构合理性。

结构化编程思想由艾慈格·迪杰斯特拉在1976年在《GOTO陈述有害论》中提出,1975年赖瑞·康斯坦丁和爱德华·尤登提出结构化设计,1978年汤姆·迪马克和爱德华·尤登等在1975年提出结构化分析,后来逐渐被完善,形成现在软件开发方法中主要采用的结构化方法。

结构化方法从功能上对系统进行划分,将系统按功能划分成各个模块,将子模块编写成子程序,通过子程序之间的结构和层次之间的耦合来解决复杂的问题。结构化方法按软件周期可划分为结构化分析、结构化设计和结构化实现。

2.5 面象对象方法

面向对象法(Object Oriented,OO),是针对面向过程提出的,是区别于传统的结构化的新方法、新思路。它将客观世界由许多不同种类的对象构成,每一个对象都有自己的内部状态和内在运行规律,不同对象的相互联系和作用构成了完整的客观世界。

OO方法起源于面向对象的编程语言(简称为OOPL),面向对象源于Simula开发语言(70年代诞生),真正的OOP(面向对象程序设计)由Smalltalk(被公认为历史上第二个面向对象的程序设计语言)奠基。Smalltalk现在被认为是最纯的OOPL。

1986年在美国举行了首届"面向对象编程、系统、语言和应用(OOPSLA'86)"国际会议,使面向对象受到世人瞩目,其后每年都举行一次,这进一步标志OO方法的研究已普及到全世界。

2.5.1 RUP统一过程

RUP(Rational Unified Process),统一软件过程是一个面向对象且基于网络的程序开发方法论。可以理解为RUP是软件工程一个方法。

软件统一过程(RUP)是Rational软件公司在1997年创造的软件工程方法 。RUP描述了如何有效地利用商业的可靠的方法开发和部署软件,是一种重量级过程(也被称作厚方法学),因此特别适用于大型软件团队开发大型项目。

2.5.2 UML统一建模语言

统一建模语言(Unified Modeling Language,UML)是一种为面向对象系统的产品进行说明、可视化和编制文档的一种标准语言,是非专利的第三代建模和规约语言。UML是面向对象设计的建模语言,独立于任何具体程序设计。

是由Grady Booch、James Rumbaugh和Ivar Jacobson在20世纪90年代中期提出的。‌ 这三位方法是信息系统和面向对象领域的著名专家,他们分别提出了不同的面向对象方法,最终这些方法被统一并发展成了UML‌

2.6 CMMI软件能力成熟度模型集成

CMMI全称Capability Maturity Model Integration For Software,软件能力成熟度模型集成,是在CMM(Capability Maturity Model For Software,软件能力成熟度模型)的基础上发展而来的。可以理解为CMMI是软件工程能力的一个衡量的方法或标准。

CMM模型自20世纪80年代末推出,并于20世纪90年代广泛应用于软件过程的改进以来,极大地促进了软件生产率的提高和软件质量的提高,为软件产业的发展和壮大做出了巨大的贡献。

3 我的理解

从开发技术层面来分,有结构化的方法和面向对象的方法,只不过目前大家普遍采用面象对象的方法进行分析、设计和开发(采用面象对象的语言)。

从组织(过程、项目)管理层面来说,有瀑布、敏捷等方法。同样现在大家大部分采用敏捷的方法组织整个软件开发过程。

CMMI 和 RUP 的区别,如下所示:

一、成熟度 vs. 方法论:CMMI 更关注过程的成熟度和改进,而 RUP 是一个具体的软件开发方法论。

二、灵活性:CMMI 提供了更多的灵活性,允许组织根据自己的需要选择和定制过程实践,而 RUP 提供了一个更固定的过程框架。

三、重点:CMMI 强调过程改进和成熟度,RUP 强调项目的迭代开发和项目管理。

四、规模:RUP 通常适用于大型项目,而 CMMI 可以适用于各种规模的项目

4 最后

本文的部分内容来自《百度百科》、《360百科》、《CSDN》,欢迎大家进行讨论,我们共同进步。

相关推荐
救救孩子把17 小时前
Cline+DeepSeek-v3-软件工程的浪潮:从切图仔到AI辅助编程
人工智能·软件工程
Lumos.011 天前
软件工程期末整理(二)
软件工程
qiu_shi_1 天前
0. 总框架
软件工程
小古jy2 天前
系统架构设计师考点—软件工程基础知识
系统架构·软件工程
码农丁丁2 天前
[研发效率]什么是软件工程生产力
软件工程·研发效率
hanbarger3 天前
面向对象分析和设计OOA/D,UML,GRASP
软件工程·uml
菠菠萝宝3 天前
【Go学习】-02-2-标准库:log、errors、bytes、io
开发语言·学习·golang·网络编程·软件工程·标准库·go1.19
菠菠萝宝3 天前
【Go学习】-01-1-入门及变量常量指针
开发语言·学习·golang·go·软件工程·web·go1.19
IH_LZH4 天前
软件工程期末总结
软件工程