软件工程及项目管理】知识点串讲第1章 软件工程技术发展思索 21.1 软件工程技术发展历程 21.2 软件与软件特征 31.3 软件工程的主要研究内容 31.4 软件技术的发展趋势 7第2章 传统的软件工程过程 82.1 什么是软件生命周期 82.2 软件生命周期的六个阶段 92.3 软件生命周期的模型 10第3章 软件工程之面向对象技术概述 12第4章 面向对象软件工程方法学实践 144.1 是“设计主导”还是“程序主导” 144.2 面向对象方法与结构化方法比较 174.3 方法学是思路不是定律 18第5章 中间件技术 19第6章 JAVA EE 技术软件工程专题 216.1 企业级 Java 216.2 J2EE 简介 226.2.1 J2EE的概念 236.2.2 J2EE 的四层模型 246.2.3 J2EE 的结构 266.3 Java EE 5 286.4 J2EE 探险者系列 296.5 J2EE 最佳实践 306.6 J2EE 与 SOA 316.7 J2EE 与 Web 2.0 316.8 Struts VS Spring 两种MVC框架比较 33第7章 面向方面编程AOP 357.1 引言 357.2 什么是方面 367.3 AOP:利与弊 377.4 Spring AOP: Spring之面向方面编程 37第8章 基于组件的软件工程-软件开发新挑战 408.1 软件开发面临的挑战 408.2 基于组件的开发中有几个危及其成功的不利因素 408.3 基于组件的软件工程 418.4 组件规范 418.5 基于组件系统开发生命周期 428.6 软件体系和基于组件的开发 438.7 UML和基于组件的系统模型 448.8 CORBA与DCOM技术 448.8.1 分布式对象技术 448.8.2 CORBA的设计模式 468.8.3 DCOM技术 508.8.4 CORBA与DCOM的主要异同 538.9 基于组件软件工程的未来 55第9章 软件测试新技术 569.1 正交试验设计 569.2 均匀试验设计 579.3 成对组合覆盖 579.4 软件测试的有效方法—确定软件测试技术 589.6 软件测试自动化框架 61第10软件工程新视角 6310.1 业发展:SOA与云计算相结合 6310.2 Agile Software Development(敏捷软件开发) 6310.3 极限编程 6510.4 可信软件 71第1章 软件工程技术发展思索1.1 软件工程技术发展历程 30多年来,软件工程的研究和实践取得了长足的进步,其中一些具有里程碑意义的进展包括: • 20世纪60年代末~70年代中期,在一系列高级语言应用的基础上,出现了结构化程序设计技术,并开发了一些支持软件开发的工具. • 20世纪70年代中期~80年代,计算机辅助软件工程(CASE)成为研究热点,并开发了一些对软件技术发展具有深远影响的软件工程环境. • 20世纪80年代中期~90年代,出现了面向对象语言和方法,并成为主流的软件开发技术;开展软件过程及软件过程改善的研究;注重软件复用和软件构件技术的研究与实践. 软件是客观事物的一种反映,客观世界的不断变化促使软件技术的不断发展,这种事物发展规律促使软件工程的产生和发展.我们仅从解决软硬件的异构性和各种软件之间的异构性角度,就可窥见软件技术发展的一种途径.如,为屏蔽计算机硬件之间的异构性发展了操作系统,为屏蔽操作系统之间和编程语言之间的异构性出现了支撑软件和中间件,为屏蔽不同中间件之间的异构性发展了Web Services技术等等;随着解决问题的不断深入,易用性和适应性要求的不断提升,以及软件技术的不断发展,还会出现更新、更复杂的异构问题,它的解决会促进软件技术的不断发展.从学科角度来看,要不断提炼所要解决问题的概念,建立相应的模型,并寻找处理方法,从而解决这些问题的概念模型和处理问题逻辑间的映射问题,如图1所示.1.2 软件与软件特征 软件是对客观世界中问题空间与解空间的具体描述,是客观事物的一种反映,是知识的提炼和“固化”.客观世界是不断变化的,因此,构造性和演化性是软件的本质特征.如何使软件模型具有更强的表达能力、更符合人类的思维模式,即如何提升计算环境的抽象层次,在一定意义上来讲,这紧紧围绕了软件的本质特征——构造性和演化性. 在高级语言出现以前,汇编语言(机器语言)是编程的工具,表达软件模型的基本概念(或语言构造)是指令,表达模型处理逻辑的主要概念(机制)是顺序和转移.显然,这一抽象层次是比较低的.高级语言的出现,例如FORTRAN语言、PASCAL语言、C语言等,使用了变量、标识符、表达式等概念作为语言的基本构造,并使用3种基本控制结构来表达软件模型的计算逻辑,因此软件开发人员可以在一个更高的抽象层次上进行程序设计.随后出现了一系列开发范型和结构化程序设计技术,实现了模块化的数据抽象和过程抽象,提高了人们表达客观世界的抽象层次,并使开发的软件具有一定的构造性和演化性.近20年来,面向对象程序设计语言的诞生并逐步流行,为人们提供了一种以对象为基本计算单元,以消息传递为基本交互手段来表达的软件模型.面向对象方法的实质是以拟人化的观点来看待客观世界,即客观世界是由一系列对象构成,这些对象之间的交互形成了客观世界中各式各样的系统[1].面向对象方法中的概念和处理逻辑更接近人们解决计算问题的思维模式,使开发的软件具有更好的构造性和演化性.目前,人们更加关注软件复用问题,构建比对象粒度更大、更易于复用的基本单元——构件,并研究以构件复用为基础的软件构造方法,更好地凸现软件的构造性和演化特性.易于复用的软件,一定是具有很好构造性和演化性的软件.1.3 软件工程的主要研究内容 从某种角度来说,软件开发的本质就是要实现“高层概念”到“低层概念”的映射,实现“高层处理逻辑”到“低层处理逻辑”的映射.对于大型软件系统的开发,这一映射是相当复杂的,涉及到有关人员、使用的技术、采取的途径以及成本和进度的约束,因此,我们可以把软件工程定义为: 软件工程(software engineering)是应用计算机科学理论和技术以及工程管理原则和方法,按照预算和进度,实现满足用户要求的软件产品的定义、开发、发布和维护的工程或以之为研究对象的学科,软件工程与其他工程一样要有自己的目标、活动和原则,软件工程框架可以概括为图2所示的内容.软件工程的基本目标是生产具有正确性、可用性及开销合宜(合算性)的产品.正确性意指软件产品达到预期功能的程度;可用性意指软件基本结构、实现及文档达到用户可用的程度;开销合宜意指软件开发、运行的整个开销满足用户的需求.以上目标的实现不论在理论上还是在实践中均存在很多问题有待解决,制约了对过程、过程模型及工程方法的选取.软件工程活动是“生产一个最终满足用户需求且达到工程目标的软件产品所需要的步骤”,主要包括需求、设计、实现、确认以及支持等活动.需求活动是在一个抽象层上建立系统模型的活动,该活动的主要产品是需求规约,是软件开发人员和客户之间契约的基础,是设计的基本输入.设计活动定义实现需求规约所需的结构,该活动的主要产品包括软件体系结构、详细的处理算法等.实现活动是设计规约到代码转换的活动.验证/确认是一项评估活动,贯穿于整个开发过程,包括动态分析和静态分析.主要技术有模型评审、代码“走查”以及程序测试等.维护活动是软件发布之后所进行的修改,包括对发现错误的修正、对环境变化所进行的必要调整等.围绕工程设计、工程支持以及工程管理,提出以下软件工程基本原则:第1条原则是选取适宜的开发风范.以保证软件开发的可持续性,并使最终的软件产品满足客户的要求. 第2条原则是采用合适的设计方法.支持模块化、信息隐蔽、局部化、一致性、适应性、构造性、集成组装性等问题的解决和实现,以达到软件工程的目标. 第3条原则是提供高质量的工程支持.提供必要的工程支持,例如配置管理、质量保证等工具和环境,以保证按期交付高质量的软件产品. 第4条原则是有效的软件工程管理.仅当对软件过程实施有效管理时,才能实现有效的软件工程. 由以上软件工程的概念和框架可以看出,软件设计的主要目标就是要实现好的结构,使开发的软件具有良好的构造性和演化性.软件工程学科所研究的内容主要包括:软件开发范型、软件设计方法、工程支持技术和工程管理技术.其中,软件开发范型涉及软件工程的“方向”问题,研究正确的求解软件的计算逻辑;软件设计方法涉及软件工程的“途径”问题,研究“高层概念模型和处理逻辑”到“低层概念模型和处理逻辑”的映射;工程支持技术和过程管理技术涉及工程过程质量和产品质量问题,研究管理学理论在软件工程中的应用.如上所述,软件开发就是实施了一个从“高层概念模型”到“低层概念模型”的映射,从“高层处理逻辑”到“低层处理逻辑”的映射,而且在这一映射中还涉及到人员、技术、成本、进度等要素,那么就必须研究映射模式即软件生产模式 问题. 分析传统产业的发展,其基本模式均是符合标准的零部件(构件)生产以及基于标准构件的产品生产(组装),其中,构件是核心和基础,“复用”是必须的手段.实践表明,这种模式是软件开发工程化、软件生产工业化的必由之路[4].因此,软件产业的发展并形成规模经济,标准构件的生产和构件的复用是关键因素. 实现软件复用的关键因素(技术和非技术因素),如图3所示,主要包括:软件构件技术(software component technology)、领域工程(domain engineering)、软件构架(software architecture)、软件再工程(software reengineering)、开放系统(open system)、软件过程(software process)、CASE技术等,以及各种非技术因素,且各种因素是相互联系、相互影响的.近年来人们认识到,要提高软件开发效率,提高软件产品质量,必须改变手工作坊式的开发方法,采取工程化的开发方法和工业化的生产技术. 青鸟工程“七五”期间,已提出了软件生产线的概念和思想[6],其中将软件的生产过程分成3类不同的生产车间,即应用构架生产车间、构件生产车间和基于构件、构架复用的应用集成组装车间.软件生产线的概念模式如图4所示.由上述软件生产线概念模式图中可以看出,在软件生产线中,软件开发人员被划分为3类:构件生产者、构件库管理者和构件复用者.这3种角色所需完成的任务是不同的,构件复用者负责进行基于构件的软件开发,包括构件查询、构件理解、适应性修改、构件组装以及系统演化等.图5给出了与上述概念图相对应的软件生产线——生产过程模型.从图4和图5中可以看出,软件生产线以软件构件/构架技术为核心,其中的主要活动体现在传统的领域工程和应用工程中,但赋予了它们新的内容,并且通过构件管理、再工程等环节将它们有机地衔接起来.另外,软件生产线中的每个活动皆有相应的方法和工具与之对应,并结合项目管理、组织管理等管理问题,形成完整的软件生产流程.1.4 软件技术的发展趋势 Internet无疑是20世纪末伟大的技术进展之一,为我们提供了一种全球范围的信息基础设施.这个不断延伸的网络基础设施,形成了一个资源丰富的计算平台,构成了人类社会的信息化、数字化基础,成为我们学习、生活和工作的必备环境.如何在未来Internet平台上进一步进行资源整合,形成巨型的、高效的、可信的和统一的虚拟环境,使所有资源能够高效、可信地为所有用户服务,成为软件技术的研究热点. Internet平台具有如下基本特征:无统一控制的“真”分布性;。