第1讲软件和软件工程毛新军教授xjmao@nudt.edu.cn计算机科学与技术系602教研室0731-(45)73649软件工程导论之用工程化的方法来开发软件©CopyrightXinjunMao软件和软件工程2本讲内容1.软件(概念、特点)2.软件危机(表现和根源)3.软件工程(概念、目标和原则)©CopyrightXinjunMao软件和软件工程3计算机软件什么是计算机软件计算机软件的特点©CopyrightXinjunMao软件和软件工程4可执行部分不可执行部分文档1文档2文档3什么是计算机软件?与计算机系统操作有关的程序以及任何与之相关的文档的集合程序©CopyrightXinjunMao软件和软件工程5什么是程序(1/2)程序:由程序设计语言所描述的、能为计算机所识别、理解和处理的语句序列程序例子Main(){inti,j;//变量定义charStr[10];i=i+j;//语句说明……}©CopyrightXinjunMao软件和软件工程6什么是程序(2/2)程序设计语言具有良好、严格语法和语义目前程序设计语言主要有以下几种类型–面向机器:如汇编语言、机器语言等–面向过程:如Fortran,Pascal,C等等–面向对象:如Java等等–面向问题:如结构化查询语言SQL等等©CopyrightXinjunMao软件和软件工程7什么是文档文档:记录软件开发活动和阶段性成果、理解软件所必需的阐述性资料–需求分析文档–软件设计文挡等编写文档目的–促进对软件的开发,管理和维护;–便于各种人员(用户,开发人员)的交流©CopyrightXinjunMao软件和软件工程8文档例子软件需求规格说明书©CopyrightXinjunMao软件和软件工程9软件特点不会老化逻辑产品(智力,无形)维护困难和复杂(完善,纠错,…...)生产只需复制软件开发性质如成本、进度等难以估计软件的开发更加依赖于开发人员的业务素质、智力、人员的合作、组织和管理©CopyrightXinjunMao软件和软件工程10本讲内容1.软件(概念、特点)2.软件危机(表现和根源)3.软件工程(概念、目标和原则)©CopyrightXinjunMao软件和软件工程11软件危机什么是软件危机软件危机的表现产生软件危机的根源解决危机的技术途径解决危机的管理途径©CopyrightXinjunMao软件和软件工程12什么是软件危机软件在开发和维护过程中遇到的一系列问题–困扰学术界和工业界–用户对软件开发缺乏信心–软件开发的高投入和高风险©CopyrightXinjunMao软件和软件工程13软件危机的表现(1of3)成本高–IBM360OS,5000多人年,耗时4年(1963-1966),花费2亿多美元–美国空军:1955年软件占总费用(计算机系统)的18%,70年60%,85年达到85%–美国全球军事指挥控制系统,硬件1亿美元,软件高达7.2亿美元计算机软件和硬件费用比010203040506070809060年代80年代计算机软件计算机硬件©CopyrightXinjunMao软件和软件工程14软件危机的表现(2of3)软件质量得不到保证–软件应用面的扩大:科学计算、军事、航空航天、工业控制、企业管理、办公、家庭–软件越来越多的应用于安全犹关(safetycritical)的系统,对软件质量提出更高的要求–80年代欧洲亚丽安娜火箭的发射失败,原因是软件错误–美国阿托拉斯火箭的发射失败,原因是软件故障–英国1986年开发的办公室信息系统Folios经4年,因性能达不到要求,1989年取消–日本第5代机因为软件问题在投入50亿美元后于1993年下马由于软件质量问题导致失败的软件项目非常多©CopyrightXinjunMao软件和软件工程15软件危机的表现(3of3)进度难以控制–项目延期比比皆是–由于进度问题而取消的软件项目较常见–只有一小部分的项目能够按期完成维护非常困难–软件维护的多样性–软件维护的复杂性–软件维护的副作用©CopyrightXinjunMao软件和软件工程16产生软件危机的根源逻辑产品,不同于物理产品复杂性高–逻辑产品,逻辑复杂性,远高于硬件复杂性–软件的复杂性随规模呈指数级上升规模大–应用扩大,代码量,1000万行,仍在不断膨胀影响软件生产率和质量的因素比较复杂–人员的能力和水平–团队合作缺乏有效、系统原理、原则、方法和工具的指导和辅助©CopyrightXinjunMao软件和软件工程17对软件开发的深层次认识开发一个具有一定规模和复杂性的软件系统与编写一个简单的程序不一样–正如建设狗窝和高楼大厦大型、复杂软件系统的开发是一项工程,必须按照工程化的方法组织软件的生产和管理,必须经过分析、设计、实现、测试、维护等一系列软件过程和活动©CopyrightXinjunMao软件和软件工程18解决危机的技术途径20世纪60年代爆发,然而实际上软件危机随着计算机软件的产生而产生,只是在此之前其问题的严重性没有引起人们的关注和重视提出有效的方法和工具支持软件开发–1968年提出软件工程概念和思想–20世纪70年代的结构化软件开发方法–20世纪80年代的面向对象的软件开发方法–新的技术:软件重用、快速原型、需求工程–典型技术:COM,Java,C++,J2EE,.Net,….–支撑工具和环境:Jbuilder,VisualStudio,WebLogic,…©CopyrightXinjunMao软件和软件工程19技术手段不能完全解决软件危机到了20世纪90年代,软件危机依然存在,甚至更为严重–应用牵引技术的发展瀑布模型结构化软件开发方法OO软件开发方法–技术推动应用的深化应用的扩大和深入–应用变得越来越大和复杂,技术变得更加力不从心–错误的观念“只要有好的软件开发方法和工具就能高效率地开发出高质量的软件”©CopyrightXinjunMao软件和软件工程20解决危机的管理途径问题出在哪里?20世纪80年代末,美国DoD和工业界开始认识到管理的重要性–美国DoD的一项研究表明,70%的项目由于管理不善导致难以控制进步、成本和质量;–进一步的研究发现:管理是影响软件项目成功开发的全局性因素,而技术只影响局部–如果软件开发组织不能对软件项目进行有效管理,就不能充分发挥软件开发方法和工具的潜力,也就不能高效率地开发出高质量的软件产品©CopyrightXinjunMao软件和软件工程21本讲内容1.软件(概念、特点)2.软件危机(表现和根源)3.软件工程(概念、目标和原则)©CopyrightXinjunMao软件和软件工程22软件工程软件危机--根源--解决途径:软件工程产生:1968年NATO计算机科学会议软件工程是运用工程的、数学的、计算机等科学概念、方法和原理来指导软件开发和管理和维护的一门学科©CopyrightXinjunMao软件和软件工程23过程方法工具软件工程软件工程构成三要素过程–管理部分方法–技术手段工具–自动或半自动地支持软件的开发和管理要素之间相互关联和支持©CopyrightXinjunMao软件和软件工程24软件工程目标(1/2)正确性–满足用户的需求(功能、性能等)可靠性–具有能够防止因概念、设计和结构等方面的不完善而造成的系统失效,具有挽回因操作不当造成软件系统失效的能力可维护性–便于对软件增加新功能、改进性能、修改错误、移植可重用性–软件易于被再次使用©CopyrightXinjunMao软件和软件工程25软件工程目标(2/2)可追踪性–对软件进行正向和反向追踪的能力可移植性–从一个环境搬迁到另一个环境可互操作性–多个软件要素相互通讯协同完成任务能力有效性–充分利用计算机的时间和空间资源©CopyrightXinjunMao软件和软件工程26软件工程原则(1/2)抽象–关注事物基本、重要的部分,忽略不相关成分–抽象可以使我们的思维聚焦于问题本质,从而简化问题,控制问题复杂度,推动复杂、庞大软件系统开发模块化–模块是程序中一个逻辑上相对独立、具有良好的接口定义的编程单位:过程、函数、类、程序包等–模块化是指将复杂的系统分解为由一个个相对独立的模块来加以实现,有助于抽象和信息隐藏以及表示复杂的系统信息隐藏–模块中的软件设计决策信息封装起来的技术,只知道它的功能以及对外的接口,而不知它的内部细节–有助于软件开发人员的注意力集中于更高的抽象层次©CopyrightXinjunMao软件和软件工程27软件工程原则(2/2)局部化–物理模块内集中逻辑上相互关联的计算资源–确保模块内各成分关系密切而模快之间的关系松散,保证模块具有良好的独立性一致性–整个软件系统均使用统一的符号、概念和术语完全性–整个软件系统不丢失任何重要的成分,软件完全实现系统所需的功能、行为和性能可验证性–软件系统应易于检查、测试和评审实践经验的总结©CopyrightXinjunMao软件和软件工程28本讲小结1.软件是程序以及相关文档的集合2.软件危机的表现,根源之一在于缺乏系统的方法和工具的指导3.软件工程:方法,工具和过程4.软件工程的目标和原则©CopyrightXinjunMao软件和软件工程29Q&AAnIntroductiontoSoftwareEngineeringPractice,Practice,andPractice