软件危机
软件危机的案例

软件危机的案例
软件危机的案例有:
1.IBMOS/360:这是一个经历了数十年,极度复杂的软件项目,被认为是软件危机的一个典型案例。
这个项目使用了1000人左右的程序员,最终产生了一套不包括在原始设计方案之中的工作系统。
在项目管理过程中,曾经出现了价值数百万美元的错误。
2.美国银行信托软件系统开发案:美国银行在1982年进入信托商业领域,并规划发展信托软件系统。
项目原订预算2千万美元,开发时程9个月,预计于1984年12月31日以前完成,然而至1987年3月都未能完成该系统,期间已投入6千万美元。
美国银行最终因为此系统不稳定而不得不放弃,并转移了340亿美元的信托账户,损失了6亿美元的信托生意商机。
除了上述案例外,还有如火箭发射失败、银行账户错误记账、导弹防御系统失败等软件危机案例。
这些案例表明,软件危机可能导致项目超出预算和进度计划,甚至可能导致严重的后果,包括人员伤亡和财产损失。
对软件的开发和维护需要采取更加严谨和系统的管理方法,以避免类似的危机发生。
软件危机

软件危机一.软件危机简介软件危机(Software Crisis) 是计算机软件在它的开发和维护过程中所遇到的一系列严重问题。
概括地说,主要包含两方面的问题:如何开发软件,怎样满足对软件日益增长的需求;如何维护数量不断膨胀的已有软件。
软件危机的原因与软件流程的整体复杂度以及软件工程这领域的不成熟有关。
这些危机可用许多方式列出:专案的进行超出预算。
专案的进行超出时间。
软件的品质低落。
软件常常不符合需求。
专案往往不能操纵和程式码难以维护。
软件危机至少有一部分可借由各式各样的流程和方法的实作来解决。
二.软件危机的危害“软件危机”使得人们开始对软件及其特性进行更深一步的研究,人们改变了早期对软件的不正确看法。
早期那些被认为是优秀的程序常常很难被别人看懂,通篇充满了程序技巧。
现在人们普遍认为优秀的程序除了功能正确,性能优良之外,还应该容易看懂、容易使用、容易修改和扩充。
程序设计语言虽然为计算机的应用开拓了无比广阔的前景,但游荡在软件世界的幽灵——“软件危机”依然存在。
因为软件的开发不仅受到程序设计的方法、结构的制约,而且受到开发周期以及软件开发成本的限制,更重要的是软件质量的保障与其程序设计的正确性关系极大。
如果所开发的软件其可靠性得不到保障,在运行中将会产生不堪设想的严重后果。
最为突出的例子是美国IBM公司于1963年~1966年开发的IBM360系列机的操作系统。
该软件系统花了大约5 000人一年的工作量,最多时,有 1000人投入开发工作,写出近100万行的源程序。
尽管投入了这么多的人力和物力,得到的结果却极其糟糕。
据统计,这个操作系统每次发行的新版本都是从前一版本中找出1000个程序错误而修正的结果。
可想而知,这样的软件质量糟到了什么地步。
难怪该项目的负责人F·D·希罗克斯在总结该项目时无比沉痛地说:“……正像一只逃亡的野兽落到泥潭中作垂死挣扎,越是挣扎,陷得越深,最后无法逃脱灭顶的灾难,……程序设计工作正像这样一个泥潭……一批批程序员被迫在泥潭中拼命挣扎,……,谁也没有料到问题竟会陷入这样的困境……。
第一讲-软件工程概述(软件危机)

结论
总之,为了消除软件危机,既要有技术措施(方法和工具),又要有必要的组织管理措施。软件工程正是从管理和技术两方面研究如何更好地开发和维护计算机软件的一门新兴学科。
课堂讨论
请针对一下几种观点发表自己的意见 编程高手不需要懂得软件工程,也能编出很好的软件。 拥有最后的开发工具和计算机就能编写优秀的软件。 软件开发进度落后,只要增加人员就能解决。
一、软件危机
1.1软件危机的介绍 什么是软件危机?
计算机软件的开发和维护过程所遇到的一系列严重问题.
软件危机的特征是什么?
对软件开发成本和进度的估计常常很不准确。 用户对“已完成的”软件系统不满意的现象经常发生。 软件产品的质量往往靠不住。 软件常常是不可维护的。 软件通常没有适当的文档资料。 软件成本在计算机系统总成本中所占的比例逐年上升。 软件开发生产率提高的速度,远远跟不上计算机应用迅速普及深入的趋势。
(2)软件开发维护中的问题
图 引入同一变动付出的代价随时间变化的趋势
正确的规格说明
错误的规格说明
需求分析
设计
正确的设计
错误的设计
对错误说明的设计
编码
正确编码
对错误说明的编码
错误编码
对错误设计的编码
测试
正确功能
潜伏的错误
不可改正的错误
可改正的错误
(2)软件开发维护中的问题
错误认为:软件开发=程序编写 软件开发只要依靠个别编程高手就能完成 轻视软件维护 Biblioteka 100%0%1955
1970
1985
———— 以上列举的仅仅是软件危机的一些明显的表现,与软件开发和维护有关的问题远远不止这些
软件危机著名案例
软件危机名词解释

软件危机名词解释软件危机名词解释概述:软件危机是指在软件开发过程中出现的一系列问题和挑战,导致项目延期、超出预算或无法交付满足需求的可靠软件的现象。
这种危机主要由于软件开发的复杂性、不完善的开发方法和技术以及需求变化等因素引起。
1. 软件开发复杂性软件开发复杂性指的是软件系统所涉及的各种组成部分之间相互关联、相互影响的复杂关系。
这包括系统规模庞大、功能繁多、多样化的用户需求、不断变化的技术环境等。
这些复杂性使得软件开发过程充满了挑战,容易导致项目延期和错误增加。
2. 不完善的开发方法和技术不完善的开发方法和技术是指在软件开发过程中使用的方法和技术不够成熟或不适应当前项目需求。
缺乏有效的需求分析和设计阶段,导致需求理解不清晰;没有规范化的代码编写标准,导致代码质量低下;缺乏有效的测试策略和工具,导致软件质量无法保证等。
这些问题会增加开发过程中的错误和重复工作,进一步加剧软件危机。
3. 需求变化需求变化是指在软件开发过程中,用户对软件功能、性能或界面等方面的要求发生变化。
由于需求变化是难以避免的,特别是在长期项目中,需求可能会随着时间推移而改变。
然而,如果没有有效的需求管理和变更控制机制,频繁的需求变化将导致项目延期、资源浪费和软件质量下降。
4. 软件危机的影响软件危机对项目和组织产生了许多负面影响。
它会导致项目延期和超出预算,给组织带来经济损失。
软件危机可能会降低软件质量和可靠性,导致系统故障、数据丢失或安全漏洞等问题。
在竞争激烈的市场环境中,软件危机还可能使组织失去市场份额和竞争优势。
总结:软件危机是指在软件开发过程中出现的一系列问题和挑战,包括软件开发复杂性、不完善的开发方法和技术以及需求变化等因素。
软件危机对项目和组织产生了经济损失、降低软件质量和可靠性以及失去市场竞争优势等负面影响。
为应对软件危机,需要采取有效的开发方法和技术、进行需求管理和变更控制,并加强项目管理和团队合作能力。
什么是软件危机?产生软件危机的原因有哪些以及它的表现有哪些?

什么是软件危机?产⽣软件危机的原因有哪些以及它的表现有哪
些?
什么是软件危机:泛指在计算机软件的开发和维护过程中所遇到的⼀系列严重问题。
出现软件危机的原因主要有:
(1)软件本⾝独有的特点确实给开发和维护带来了困难
(2)软件开发和维护过程不规范
(3)缺乏软件开发的经验和有关软件开发数据的积累
(4)轻视,⼈们在制定计划时总会有⼀些天马⾏空的想法和要求,轻视是⼀个最⼤的错误。
(5)忽视软件需求分析的重要性、忽视软件的可理解性、⽂档不完备、轻视软件的可维护性、过分强调编码技巧等等⽅⾯。
(6)⽤户与开发⼈员的沟通问题,从⽽技术⼈员获取的需求不够全⾯。
软件危机的表现:
(1)软件开发没有真正的计划性,对软件开发进度和软件开发成本的估计常常很不准确,计划的制定带有很⼤的盲⽬因素。
(2)对于软件需求信息的获取常常不充分,软件产品往往不能真正地满⾜⽤户的实际需求。
(3)缺乏良好的软件质量评测⼿段,从⽽导致软件产品的质量常常得不到保证。
(4)对于软件的可理解性、可维护性认识不够;软件的可复⽤性、可维护性不如⼈意。
(5)软件开发过程没有实现“规范化”,缺乏必要的⽂档资料或者⽂档资料不合格、不准确,难以进⾏专业维护。
(6)软件开发的⼈⼒成本持续上升。
(7)缺乏⾃动化的软件开发技术,软件开发的⽣产率依然低下,远远满⾜不了急剧增长的软件需求。
软件危机

软件危机基本概念软件工程:在计算机软件的开发和维护过程中所遇到的一系列严重问题。
背景原因(软件工程的发展史……)落后的软件生产方式无法满足迅速增长的计算机软件需求,从而导致软件开发与维护过程中出现一系列严重问题的现象。
造成软件危机的原因与软件自身的特点有关,也与软件开发人员在开发和维护时期所采取的生产凡是、方法、技术有关。
可概括为以下几个风方面:1)软件是计算机系统中的逻辑部件,软件产品往往规模庞大,结构复杂,给软件的开发和维护带来客观的困难;2)软件开发的管理困难;3)软件开发费用不断增加,维护费用几句上升,直接威胁计算机应用的扩大;4)软件开发技术落后;5)生产方式落后;6)开发工具落后,生产效率提高缓慢。
主要问题软件危机主要包含两方面的问题:1)如何开发软件以满足对软件日益增长的需求;2)如何维护数量不断增长的已有软件。
表现形式软件危机的主要表现形式如下:1)对软件开发成本和研制进度的估计常常很不精确;2)“已完成”的软件不能满足用户需求;3)软件产品质量差,可靠性得不到保证;4)软件产品可维护性差;5)软件成本在计算机系统总成本中所占的比例逐年上升;6)软件开发生产率提高的速度远远跟不上计算机应用速度普及深入的趋势。
解决途径软件危机的解决途径如下:1)首先应该对计算机软件有一个正确的人是,彻底清除“软件就是程序”的错误概念;2)要使用好的开发技术和方法,并且要不断研究探索更好、更有效的技术和方法。
尽快消除在计算机系统早期发展阶段形成的一些错误观念和做法;3)要有良好的组织、严谨的管理,各类人员要相互配合,共同完成任务。
充分让人认识软件开发不是某种个体劳动的神秘技巧。
4)应该开发和使用好的软件开发工具,从而可以有效地提高软件生产效率。
软件危机

缺乏必要的文档资料或者文档资料不合格,将给软件开发和维护带来许多严重的困难和问题
(3)软件生产率很低
伴随计算机的普及,整个社会对计算机应用的需求越来越大。但软件的生产却还沿用“手工作坊”的生产方式,人工编程生产。生产效率仅提高了几倍。生产能力极其低下。
(4)硬、软件供需失衡
社会大量需求,生产成本高,生产过程控制复杂,生产效率低等等因素构成软件生产的恶性循环。
2.软件危机的具体体现
软件危机
软件危机是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。这些严重的问题阻碍着软件生产的规模化、商品化以及生产效率。使得软件的开发和生产成为制约软件产业发展的“瓶径”。
1.软件危机的由来
(1)硬件生产率大幅提高
如今,计算机的发展已进入一个新的历史阶段。硬件产品已系列化、标准化,“即插即用”。硬件产品的生产可以采用最高精尖的现代化工具和手段、自动成批生产。生产效率几百万倍的提高。生产能力过剩。
为使系统适应新的硬件环境,或根据用户的需要在原系统中增加一些新的功能,又有可能增加系统中的错误。
⑹ 软件缺少适当的文档资料
文档资料是软件的重要组成部分。
实际上,软件的文档资料是开发组织和用户的之间权利和义务的合同书,是系统管理者、总体设计者向开发人员下达的任务书,是系统维护人员的技术指导手册,是用户的操作说明书。
⑷ 软件产品质量无法保证
系统中的错误难以消除。软件是逻辑产品,质量问题很难以统一的标准度量,因而造成质量控制困难。
软件产品并不是没有错误,而是盲目检测很难发现错误,而隐藏下来的错误往往是造成重大事故的隐患。
⑸ 软件产品难以维护
软件产品本质上是开发人员的代码化的逻辑思维活动,他人难以替代。除非是开发者本人,否则很难及时检测、排除系统故障。
软件危机与软件工程

软件危机与软件工程软件危机与软件工程概述软件危机是指软件开发过程中出现的一连串问题和挑战,导致项目延期、超出预算或质量不佳的情况。
而软件工程则致力于解决软件开发过程中的各种挑战和问题,并提供一种可靠且高效的方法来开发高质量的软件。
软件危机的原因软件危机的原因有多方面的因素,主要包括以下几点:1. 需求不明确:在软件开发初期,客户对软件的需求往往模糊不清或者发生变化,导致软件开发团队无法准确理解客户的需求,从而难以开发出满足客户期望的软件。
2. 技术挑战:软件开发涉及多种技术和复杂的编程环境,开发人员需要不断学习和适应新的技术,但往往时间紧迫,导致技术跟不上进展,造成软件质量不佳。
3. 人员管理:软件开发涉及多个团队成员的合作,如果人员之间无法有效沟通和协作,就会影响软件的开发进度和质量。
4. 项目管理:项目管理对软件开发至关重要,如果项目管理不善,容易导致进度延误、资源浪费等问题。
软件工程的解决方案软件工程是一种以工程化的方式来开发软件的方法,并提供了解决软件开发挑战的一系列技术和方法。
以下是软件工程在解决软件危机中的一些解决方案:1. 需求工程:通过系统化的需求搜集和分析方法,帮助开发团队更全面地理解客户需求,避免需求不明确的问题。
2. 软件架构设计:通过良好的软件架构设计,可以确保软件的可扩展性和可维护性,降低软件开发过程中的技术难题。
3. 项目管理:采用敏捷的项目管理方法可以更好地应对需求变化和项目进度控制,保证软件开发的高效进行。
4. 质量保证:软件是软件工程中的重要环节,通过各种方法如单元、集成和系统等,可以确保软件质量。
软件危机背后的挑战虽然软件工程提供了一套解决软件危机的方法和技术,但在实践中仍然面临一些挑战:1. 技术进步:软件开发领域的技术在不断进步,开发团队需要不断学习和适应新的技术,才能跟上潮流并提供高质量的软件。
2. 项目规模:随着软件项目规模和复杂度增加,开发团队需要更多的资源和时间来完成项目,项目管理和资源分配成为挑战。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
软件危机落后的软件生产方式无法满足迅速增长的计算机软件需求,从而导致软件开发与维护过程中出现一系列严重问题的现象。
20 世纪60年代以前,计算机主要为电子管计算机,体积大,速度慢,性能较差,计算机刚刚投入实际使用,软件设计往往只是为了一个特定的应用而在指定的计算机上设计和编制,采用密切依赖于计算机的机器代码或汇编语言,软件的规模比较小,文档资料通常也不存在,很少使用系统化的开发方法,设计软件往往等同于编制程序,基本上是个人设计、个人使用、个人操作、自给自足的私人化的软件生产方式。
1964年4月,以IBM360为代表德大容量、高速度的计算机—集成电路计算机出现,使计算机的应用范围迅速扩大,软件开发急剧增长。
高级语言开始出现;操作系统的发展引起了计算机应用方式的变化;大量数据处理导致第一代数据库管理系统的诞生。
软件系统的规模越来越大,复杂程度越来越高,软件可靠性问题也越来越突出。
原来的个人设计、个人使用的方式不再能满足要求,迫切需要改变软件生产方式,提高软件生产率,软件危机开始爆发。
早期出现的软件危机主要表现在:①软件开发费用和进度失控。
费用超支、进度拖延的情况屡屡发生。
有时为了赶进度或压成本不得不采取一些权宜之计,这样又往往严重损害了软件产品的质量。
②软件的可靠性差。
尽管耗费了大量的人力物力,而系统的正确性却越来越难以保证,出错率大大增加,由于软件错误而造成的损失十分惊人。
③生产出来的软件难以维护。
很多程序缺乏相应的文档资料,程序中的错误难以定位,难以改正,有时改正了已有的错误又引入新的错误。
随着软件的社会拥有量越来越大,维护占用了大量人力、物力和财力。
进入80年代以来,尽管软件工程研究与实践取得了可喜的成就,软件技术水平有了长足的进展,但是软件生产水平依然远远落后于硬件生产水平的发展速度。
为此,1968 年北大西洋公约组织的计算机科学家在联邦德国召开国际会议,第一次讨论软件危机问题,并正式提出“软件工程”一词,从此一门新兴的工程学科——软件工程学——为研究和克服软件危机应运而生。
当前,类似的软件问题依然存在,具体体现在:1. 软件开发进度难以预测拖延工期几个月甚至几年的现象并不罕见,这种现象降低了软件开发组织的信誉。
以丹佛新国际机场为例:该机场规模是曼哈顿机场的两倍,宽为希思机场的10倍,可以全天侯同时起降三架喷气式客机;投资1.93亿美元建立了一个地下行李传送系统,总长21英里,有4,000台遥控车,可按不同线路在20家不同的航空公司柜台、登机门和行李领取处之间发送和传递行李;支持该系统的是5,000个电子眼、400台无线电接受机、56台条形码扫描仪和100台计算机。
按原定计划要在1993年万圣节前启用,但一直到1994年6月,机场的计划者还无法预测行李系统何时能达到可使机场开放的稳定程度。
2. 软件开发成本难以控制投资一再追加,令人难于置信。
往往是实际成本比预算成本高出一个数量级。
而为了赶进度和节约成本所采取的一些权宜之计又往往损害了软件产品的质量,从而不可避免地会引起用户的不满。
3. 用户对产品功能难以满足开发人员和用户之间很难沟通、矛盾很难统一。
往往是软件开发人员不能真正了解用户的需求,而用户又不了解计算机求解问题的模式和能力,双方无法用共同熟悉的语言进行交流和描述。
在双方互不充分了解的情况下,就仓促上阵设计系统、匆忙着手编写程序,这种“闭门造车”的开发方式必然导致最终的产品不符合用户的实际需要。
4. 软件产品质量无法保证系统中的错误难以消除。
软件是逻辑产品,质量问题很难以统一的标准度量,因而造成质量控制困难。
软件产品并不是没有错误,而是盲目检测很难发现错误,而隐藏下来的错误往往是造成重大事故的隐患。
5. 软件产品难以维护软件产品本质上是开发人员的代码化的逻辑思维活动,他人难以替代。
除非是开发者本人,否则很难及时检测、排除系统故障。
为使系统适应新的硬件环境,或根据用户的需要在原系统中增加一些新的功能,又有可能增加系统中的错误。
6. 软件缺少适当的文档资料文档资料是软件必不可少的重要组成部分。
实际上,软件的文档资料是开发组织和用户的之间权利和义务的合同书,是系统管理者、总体设计者向开发人员下达的任务书,是系统维护人员的技术指导手册,是用户的操作说明书。
缺乏必要的文档资料或者文档资料不合格,将给软件开发和维护带来许多严重的困难和问题。
最典型失败系统的例子是:IBM公司开发OS/360系统,共有4000多个模块,约100万条指令,投入5000人年,耗资数亿美元,结果还是延期交付。
在交付使用后的系统中仍发现大量(2000个以上)的错误。
原因软件工程研究结果表明,软件危机的原因主要有两方面:与软件本身的特点有关软件不同于硬件,它是计算机系统中的逻辑部件而不是物理部件;软件样品即是产品,试制过程也就是生产过程;软件不会因使用时间过长而“老化”或“用坏”;软件具有可运行的行为特性,在写出程序代码并在计算机上试运行之前,软件开发过程的进展情况较难衡量,软件质量也较难评价,因此管理和控制软件开发过程十分困难;软件质量不是根据大量制造的相同实体的质量来度量,而是与每一个组成部分的不同实体的质量紧密相关,因此,在运行时所出现的软件错误几乎都是在开发时期就存在而一直未被发现的,改正这类错误通常意味着改正或修改原来的设计,这就在客观上使得软件维护远比硬件维护困难;软件是一种信息产品,具有可延展性,属于柔性生产,与通用性强的硬件相比,软件更具有多样化的特点,更加接近人们的应用问题。
随着计算机应用领域的扩大,99%的软件应用需求已不再是定义良好的数值计算问题,而是难以精确描述且富于变化的非数值型应用问题。
因此,当人们的应用需求变化发展的时候,往往要求通过改变软件来使计算机系统满足新的需求,维护用户业务的延续性。
来自于软件开发人员的弱点其一,软件产品是人的思维结果,因此软件生产水平最终在相当程度上取决于软件人员的教育、训练和经验的积累;其二,对于大型软件往往需要许多人合作开发,甚至要求软件开发人员深入应用领域的问题研究,这样就需要在用户与软件人员之间以及软件开发人员之间相互通讯,在此过程中难免发生理解的差异,从而导致后续错误的设计或实现,而要消除这些误解和错误往往需要付出巨大的代价;其三,由于计算机技术和应用发展迅速,知识更新周期加快,软件开发人员经常处在变化之中,不仅需要适应硬件更新的变化,而且还要涉及日益扩大的应用领域问题研究;软件开发人员所进行的每一项软件开发几乎都必须调整自身的知识结构以适应新的问题求解的需要,而这种调整是人所固有的学习行为,难以用工具来代替。
软件生产的这种知识密集和人力密集的特点是造成软件危机的根源所在。
从软件开发危机的种种表现和软件开发作为逻辑产品的特殊性可以发现软件开发危机的原因:(1)用户需求不明确在软件开发过程中,用户需求不明确问题主要体现在四个方面:在软件开发出来之前,用户自己也不清楚软件开发的具体需求;用户对软件开发需求的描述不精确,可能有遗漏、有二义性、甚至有错误;在软件开发过程中,用户还提出修改软件开发功能、界面、支撑环境等方面的要求;软件开发人员对用户需求的理解与用户本来愿望有差异。
(2)缺乏正确的理论指导缺乏有力的方法学和工具方面的支持。
由于软件开发不同于大多数其他工业产品,其开发过程是复杂的逻辑思维过程,其产品极大程度地依赖于开发人员高度的智力投入。
由于过分地依靠程序设计人员在软件开发过程中的技巧和创造性,加剧软件开发产品的个性化,也是发生软件开发危机的一个重要原因。
(3)软件开发规模越来越大随着软件开发应用范围的增广,软件开发规模愈来愈大。
大型软件开发项目需要组织一定的人力共同完成,而多数管理人员缺乏开发大型软件开发系统的经验,而多数软件开发人员又缺乏管理方面的经验。
各类人员的信息交流不及时、不准确、有时还会产生误解。
软件开发项目开发人员不能有效地、独立自主地处理大型软件开发的全部关系和各个分支,因此容易产生疏漏和错误。
(4)软件开发复杂度越来越高软件开发不仅仅是在规模上快速地发展扩大,而且其复杂性也急剧地增加。
软件开发产品的特殊性和人类智力的局限性,导致人们无力处理“复杂问题”。
所谓“复杂问题”的概念是相对的,一旦人们采用先进的组织形式、开发方法和工具提高了软件开发效率和能力,新的、更大的、更复杂的问题又摆在人们的面前。
以美国宇航局的软件系统为例:1963年水星计划系统200万条指令1967年双子星座计划系统400万条指令1973年阿波罗计划系统1000万条指令1979年哥伦比亚航天飞机系统4000万条指令假设1个人一年生产一万条有效指令,那么是否4000人生产一年,或400人生产10年就能完成任务呢?答案是否定的。
一万条指令的复杂度决不仅仅是100条指令复杂度的100倍。
伴随计算机的普及,整个社会对计算机应用的需求越来越大。
但软件的生产却还沿用"手工作坊"的生产方式,生产能力极其低下。
人工编程生产。
生产效率仅提高了几倍。
解决途径软件工程诞生于60年代末期,它作为一个新兴的工程学科,主要研究软件生产的客观规律性,建立与系统化软件生产有关的概念、原则、方法、技术和工具,指导和支持软件系统的生产活动,以期达到降低软件生产成本、改进软件产品质量、提高软件生产率水平的目标。
软件工程学从硬件工程和其他人类工程中吸收了许多成功的经验,明确提出了软件生命周期的模型,发展了许多软件开发与维护阶段适用的技术和方法,并应用于软件工程实践,取得良好的效果。
在软件开发过程中人们开始研制和使用软件工具,用以辅助进行软件项目管理与技术生产,人们还将软件生命周期各阶段使用的软件工具有机地集合成为一个整体,形成能够连续支持软件开发与维护全过程的集成化软件支援环境,以期从管理和技术两方面解决软件危机问题。
此外,人工智能与软件工程的结合成为80年代末期活跃的研究领域。
基于程序变换、自动生成和可重用软件等软件新技术研究也已取得一定的进展,把程序设计自动化的进程向前推进一步。
在软件工程理论的指导下,发达国家已经建立起较为完备的软件工业化生产体系,形成了强大的软件生产能力。
软件标准化与可重用性得到了工业界的高度重视,在避免重用劳动,缓解软件危机方面起到了重要作用。