八、维护
软件维护的概念
定义
软件维护就是在软件已经交付使用之后,为了改正错误或满足新需要而修改软件的过程,其基本任务是保证软件在一个相当长的时期能够正常运行。
分类
(1) 改正性维护
在任何大型程序的使用期间,用户必然会发现程序错误,并且把他们遇到的问题报告给维护人员。把诊断和
改正错误的过程称为改正性维护。
(2) 适应性维护
适应性维护,也就是为了和变化了的环境适当地配合而进行的修改软件的活动,是既必要又经常的维护活动。
(3) 完善性维护
为了满足用户在使用团建过程中提出的新功能或者修改已有功能的建议,需要进行完善性维护。这项维护活
动通常占软件维护工作的大部分。
(4) 预防性维护
当为了改进未来的可维护性或可靠性,或为了给未来的改进奠定更好的基础而修改软件,这项维护活动通常
称为预防性维护。
软件维护的特点
非结构化维护
① 流程
a. 软件配置的唯一成分是程序代码,维护活动从艰苦地评价程序代码开始;
b. 由于程序内部文档不足,而对于软件结构、全程数据结构、系统接口、性能和设计约束等会产生误解;
c. 对程序代码所做的改动的后果是难于估量的;
d. 没有测试方面的文档,不可能进行回归测试。
② 特点
非结构化维护需要付出很大代价,这种维护方式是没有使用良好定义的方法学开发出来的软件的必然结果。
结构化维护
① 流程
a. 有一个完整的软件配置存在,维护工作从评价设计文档开始;
b. 确定软件重要的结构特点、性能特点以及接口特点;
c. 估量要求的改动将带来的影响,并且计划实施途径;
d. 修改设计并且对所做的修改进行仔细复查;
e. 编写相应的源程序代码;
f. 使用在测试说明书中包含的信息进行回归测试;
g. 把修改后的软件再次交付使用。
② 特点
结构化维护是在软件开发的早期应用软件工程方法学的结果。有了软件的完整配置能减少精力的浪费并且能提高维护的总体质量。
维护代价高昂
软件维护中无形的代价有:
(1)因为可用的资源必须供维护任务使用,以致耽误甚至丧失了开发的良机。
(2) 当看来合理的有关改错或修改的要求不能及时满足时将引起用户不满。
(3) 由于维护时的改动,在软件中引入了潜伏的错误,从而降低了软件的质量。
(4) 当必须把软件工程师调去从事维护工作时,将在开发过程中造成混乱。
(5) 生产率的大幅度下降。