导航:首页 > 工程技术 > pdl语言软件工程

pdl语言软件工程

发布时间:2021-08-14 02:05:37

软件工程相关基础问题

浅论软件工程
软件工程 (Software Engineering,简称为SE)是一门研究用工程化方法构建和维护有效的、实用的和高质量的软件的学科。它涉及到程序设计语言,数据库,软件开发工具,系统平台,标准,设计模式等方面。
在现代社会中,软件应用于多个方面。典型的软件比如有电子邮件,嵌入式系统,人机界面,办公套件,操作系统,编译器,数据库,游戏等。同时,各个行业几乎都有计算机软件的应用,比如工业,农业,银行,航空,政府部门等。这些应用促进了经济和社会的发展,使得人们的工作更加高效,同时提高了生活质量。
软件工程师是对应用软件创造软件的人们的统称,软件工程师按照所处的领域不同可以分为系统分析员,软件设计师,系统架构师,程序员,测试员等等。人们也常常用程序员来泛指各种软件工程师。
软件工程的主要课程:
外语、高等数学、线性代数、高等代数、电子技术基础、离散数学、计算机引论(C语言)、数据结构、C++程序设计、汇编语言程序设计、算法设计与分析、计算机组成原理与体系结构、数据库系统、计算机网络、软件工程、软件测试技术、软件需求与项目管理、软件设计实例分析、CMM/ISO9000等。
软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。
(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。
(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。
(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。
[编辑本段]软件工程的定义
软件工程一直以来都缺乏一个统一的定义,很多学者、组织机构都分别给出了自己的定义:
(1)。Barry Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。
(2)。IEEE在软件工程术语汇编中的定义:软件工程是:1.将系统化的、严格约束的、可量化的方法应用于软件的开发、运行和维护,即将工程化应用于软件;2.在1中所述方法的研究
(3)。Fritz Bauer在NATO会议上给出的定义:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。
目前比较认可的一种定义认为:软件工程是研究和应用如何以系统性的、规范化的、可定量的过程化方法去开发和维护软件,以及如何把经过时间考验而证明正确的管理技术和当前能够得到的最好的技术方法结合起来。
(4)。《计算机科学技术网络全书》中的定义:软件工程是应用计算机科学、数学及管理科学等原理,开发软件的工程。软件工程借鉴传统工程的原则、方法,以提高质量、降低成本。其中,计算机科学、数学用于构建模型与算法,工程科学用于制定规范、设计范型(paradigm)、评估成本及确定权衡,管理科学用于计划、资源、质量、成本等管理。
[编辑本段]软件工程学的内容
软件工程学的主要内容是软件开发技术和软件工程管理.
软件开发技术包含软件工程方法学、软件工具和软件开发环境;软件工程管理学包含软件工程经济学和软件管理学。
[编辑本段]软件工程基本原理
著名软件工程专家B.Boehm综合有关专家和学者的意见并总结了多年来开发软件的经验,于1983年在一篇论文中提出了软件工程的七条基本原理。Boehm
(1)用分阶段的生存周期计划进行严格的管理。
(2)坚持进行阶段评审。
(3)实行严格的产品控制。
(4)采用现代程序设计技术。
(5)软件工程结果应能清楚地审查。
(6)开发小组的人员应该少而精。
(7)承认不断改进软件工程实践的必要性。
B.Boehm指出,遵循前六条基本原理,能够实现软件的工程化生产;按照第七条原理,不仅要积极主动地采纳新的软件技术,而且要注意不断总结经验。
软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。
(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。
(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。
(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则
[编辑本段]软件工程必须遵循什么原则
围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则:
(1)选取适宜的开发模型
该原则与系统设计有关。在系统设计中,软件需求、硬件需求以及其它因素间是相互制约和影响的,经常需要权衡。因此,必需认识需求定义的易变性,采用适当的开发模型,保证软件产品满足用户的要求。
(2)采用合适的设计方法
在软件设计中,通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现,以达到软件工程的目标。
(3)提供高质量的工程支撑
工欲善其事,必先利其器。在软件工程中,软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。
(4)重视软件工程的管理
软件工程的管理直接影响可用资源的有效利用,生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此,仅当软件过程予以有效管理时,才能实现有效的软件工程。
软件工程是指导计算机软件开发和维护的工程学科。
采用工程的概念、原理、 技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来,这就是软件工程。
软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对软件产品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策略就是“各个击破”,也就是对问题进行分解然后再分别解决各个子问题的策略。软件工程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立的任务,然后逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候,从对任务的抽象逻辑分析开始,一个阶段一个阶段地进行开发。前一个阶段任务的完成是开始进行后一个阶段工作的前提和基础,而后一阶段任务的完成通常是使前一阶段提出的解法更进一步具体化,加进了更多的物理细节。每一个阶段的开始和结束都有严格标准,对于任何两个相邻的阶段而言,前一阶段的结束标准就是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查和管理复审,从技术和管理两方面对这个阶段的开发成果进行检查,通过之后这个阶段才算结束;如果检查通不过,则必须进行必要的返工,并且返工后还要再经过审查。审查的一条主要标准就是每个阶段都应该交出“最新式的”(即和所开发的软件完全一致的)高质量的文档资料,从而保证在软件开发工程结束时有一个完整准确的软件配置交付使用。文档是通信的工具,它们清楚准确地说明了到这个时候为止,关于该项工程已经知道了什么,同时确立了下一步工作的基础。此外,文档也起备忘录的作用,如果文档不完整,那么一定是某些工作忘记做了,在进入生存周期的下一阶段之前,必须补足这些遗漏的细节。在完成生存周期每个阶段的任务时,应该采用适合该阶段任务特点的系统化的技术方法——结构分析或结构设计技术。
把软件生存周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,从而降低了整个软件开发工程的困难程度;在软件生存周期的每个阶段都采用科学的管理技术和良好的技术方法,而且在每个阶段结束之前都从技术和管理两个角度进行严格的审查,合格之后才开始下一阶段的工作,这就使软件开发工程的全过程以一种有条不紊的方式进行,保证了软件的质量,特别是提高了软件的可维护性。总之,采用软件工程方法论可以大大提高软件开发的成功率,软件开发的生产率也能明显提高。
目前划分软件生存周期阶段的方法有许多种,软件规模、种类、开发方式、开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件生存周期的阶段时应该遵循的一条基本原则就是使各阶段的任务彼此间尽可能相对独立,同一阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂程度,简化不同阶段之间的联系,有利于软件开发工程的组织管理。一般说来,软件生存周期由软件定义、软件开发和软件维护三个时期组成,每个时期又进一步划分成若干个阶段。下面的论述主要针对应用软件,对系统软件也基本适用。
软件定义时期的任务是确定软件开发工程必须完成的总目标;确定工程的可行性,导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程需要的资源和成本,并且制定工程进度表。这个时期的工作通常又称为系统分析,由系统分析员负责完成。软件定义时期通常进一步划分成三个阶段,即问题定义、可行性研究和需求分析。
开发时期具体设计和实现在前一个时期定义的软件,它通常由下述四个阶段组成:总体设计,详细设计,编码和单元测试,综合测试。
维护时期的主要任务是使软件持久地满足用户的需要。具体地说,当软件在使用过程中发现错误时应该加以改正;当环境改变时应该修改软件以适应新的环境;当用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再进一步划分阶段,但是每一次维护活动本质上都是一次压缩和简化了的定义和开发过程。
下面扼要介绍软件生存周期每个阶段的基本任务和结束标准。
1问题定义
问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的,但是在实践中它却可能是最容易被忽视的一个步骤。
通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都满意的文档。
问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的时间。
2可行性研究
这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。
可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范围,探索这个问题是否值得去解,是否有可行的解决办法。
在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。
可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值得投资的工程项目,可以避免更大的浪费。
3需求分析
这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。
用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻辑模型。
在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有效地防止和克服急于着手进行具体设计的倾向。
4总体设计
这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”
首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑下述几类可能的方案:
低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工作。
中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的能力在实践中将证明是很有价值的。
高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功能和特点。
系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种方案的成本和效益,还应该在充分权衡各种方案的利弊的基础上,推荐一个较好的系统 (最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分析员推荐的系统,则可以着手完成本阶段的另一项主要工作。
上面的工作确定了解决问题的策略以及目标系统需要哪些程序,但是,怎样设计这些程序呢?结构设计的一条基本原理就是程序应该模块化,也就是一个大程序应该由许多规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二项主要任务就是设计软件的结构,也就是确定程序由哪些模块组成以及模块间的关系。通常用层次图或结构图描绘软件的结构。
5详细设计
总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段的任务就是把解法具体化,也就是回答下面这个关键问题:“应该怎样具体地实现这个系统呢?”
这个阶段的任务还不是编写程序,而是设计出程序的详细规格说明。这种规格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图,它们应该包含必要的细节,程序员可以根据它们写出实际的程序代码。
通常用HIPO图(层次图加输入/处理/输出图)或PDL语言(过程设计语言)描述详细设计的结果。
6编码和单元测试
这个阶段的关键任务是写出正确的容易理解、容易维护的程序模块。
程序员应该根据目标系统的性质和实际环境,选取一种适当的高级程序设计语言(必要时用汇编语言),把说细设计的结果翻译成用选定的语言书写的程序,并且仔细测试编写出的每一个模块。
7综合测试
这个阶段的关键任务是通过各种类型的测试(及相应的调试)使软件达到预定的要求。
最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构,把经过单元测试检验的模块按某种选定的策略装配起来,在装配过程中对程序进行必要的测试。所谓验收测试则是按照规格说明书的规定(通常在需求分析阶段确定),由用户(或在用户积极参加下)对目标系统进行验收。
必要时还可以再通过现场测试或平行运行等方法对目标系统进一步测试检验。
为了使用户能够积极参加验收测试,并且在系统投入生产性运行以后能够正确有效地使用这个系统,通常需要以正式的或非正式的方式对用户进行培训。
通过对软件测试结果的分析可以预测软件的可靠性;反之,根据对软件可靠性的要求也可以决定测试和调试过程什么时候可以结束。
应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下来,做为软件配置的一个组成成分。
8软件维护
维护阶段的关键任务是,通过各种必要的维护活动使系统持久地满足用户的需要。
通常有四类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,即根据用户的要求改进或扩充软件使它更完善;预防性维护,即修改软件为将来的维护活动预先做准备。
虽然没有把维护阶段进一步划分成更小的阶段,但是实际上每一项维护活动都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。
都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。

❷ 软件开发工程

软件工程
软件工程一直以来都缺乏一个统一的定义,很多学者、组织机构都分别给出了自己的定义:

Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。

IEEE:软件工程是开发、运行、维护和修复软件的系统方法。

Fritz Bauer:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。

软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。

(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。

(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。

(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。

软件工程必须遵循什么原则

围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则:

(1)选取适宜的开发模型

该原则与系统设计有关。在系统设计中,软件需求、硬件需求以及其它因素间是相互制约和影响的,经常需要权衡。因此,必需认识需求定义的易变性,采用适当的开发模型,保证软件产品满足用户的要求。

(2)采用合适的设计方法

在软件设计中,通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现,以达到软件工程的目标。

(3)提供高质量的工程支撑

工欲善其事,必先利其器。在软件工程中,软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。

(4)重视软件工程的管理

软件工程的管理直接影响可用资源的有效利用,生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此,仅当软件过程予以有效管理时,才能实现有效的软件工程。

软件工程是指导计算机软件开发和维护的工程学科。

采用工程的概念、原理、 技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来,这就是软件工程。

软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是

在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对

软件产品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策

略就是“各个击破”,也就是对问题进行分解然后再分别解决各个子问题的策略

。软件工程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题

进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立

的任务,然后逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候,

从对任务的抽象逻辑分析开始,一个阶段一个阶段地进行开发。前一个阶段任务

的完成是开始进行后一个阶段工作的前提和基础,而后一阶段任务的完成通常是

使前一阶段提出的解法更进一步具体化,加进了更多的物理细节。每一个阶段的开

始和结束都有严格标准,对于任何两个相邻的阶段而言,前一阶段的结束标准就

是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查

和管理复审,从技术和管理两方面对这个阶段的开发成果进行检查,通过之后这

个阶段才算结束;如果检查通不过,则必须进行必要的返工,并且返工后还要再

经过审查。审查的一条主要标准就是每个阶段都应该交出“最新式的”(即和所

开发的软件完全一致的)高质量的文档资料,从而保证在软件开发工程结束时有

一个完整准确的软件配置交付使用。文档是通信的工具,它们清楚准确地说明了

到这个时候为止,关于该项工程已经知道了什么,同时确立了下一步工作的基础

。此外,文档也起备忘录的作用,如果文档不完整,那么一定是某些工作忘记做

了,在进入生存周期的下一阶段之前,必须补足这些遗漏的细节。在完成生存周

期每个阶段的任务时,应该采用适合该阶段任务特点的系统化的技术方法——结

构分析或结构设计技术。

把软件生存周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简

单,便于不同人员分工协作,从而降低了整个软件开发工程的困难程度;在软件

生存周期的每个阶段都采用科学的管理技术和良好的技术方法,而且在每个阶段

结束之前都从技术和管理两个角度进行严格的审查,合格之后才开始下一阶段的

工作,这就使软件开发工程的全过程以一种有条不紊的方式进行,保证了软件的

质量,特别是提高了软件的可维护性。总之,采用软件工程方法论可以大大提高

软件开发的成功率,软件开发的生产率也能明显提高。

目前划分软件生存周期阶段的方法有许多种,软件规模、种类、开发方式、

开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件

生存周期的阶段时应该遵循的一条基本原则就是使各阶段的任务彼此间尽可能相

对独立,同一阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂程

度,简化不同阶段之间的联系,有利于软件开发工程的组织管理。一般说来,软

件生存周期由软件定义、软件开发和软件维护三个时期组成,每个时期又进一步

划分成若干个阶段。下面的论述主要针对应用软件,对系统软件也基本适用。

软件定义时期的任务是确定软件开发工程必须完成的总目标;确定工程的可行

性,导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程

需要的资源和成本,并且制定工程进度表。这个时期的工作通常又称为系统分析

,由系统分析员负责完成。软件定义时期通常进一步划分成三个阶段,即问题定

义、可行性研究和需求分析。

开发时期具体设计和实现在前一个时期定义的软件,它通常由下述四个阶段组

成:总体设计,详细设计,编码和单元测试,综合测试。

维护时期的主要任务是使软件持久地满足用户的需要。具体地说,当软件在

使用过程中发现错误时应该加以改正;当环境改变时应该修改软件以适应新的环境

;当用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再

进一步划分阶段,但是每一次维护活动本质上都是一次压缩和简化了的定义和开

发过程。

下面扼要介绍软件生存周期每个阶段的基本任务和结束标准。

1问题定义

问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道

问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最

终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的

,但是在实践中它却可能是最容易被忽视的一个步骤。

通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和

规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员

扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份

书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都

满意的文档。

问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的

时间。

2可行性研究

这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解

决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的

系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。

可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范

围,探索这个问题是否值得去解,是否有可行的解决办法。

在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究

阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更

准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效

益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。

可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的

重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进

行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值

得投资的工程项目,可以避免更大的浪费。

3需求分析

这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,

目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。

用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表

达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道

怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统

分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确

认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻

辑模型。

在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因

此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术

专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的

细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结

构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完

整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有

效地防止和克服急于着手进行具体设计的倾向。

4总体设计

这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”

首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用

计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是

人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑

下述几类可能的方案:

低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工

作。

中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用

起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没

有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的

能力在实践中将证明是很有价值的。

高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功

能和特点。

系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种

方案的成本和效益,还应该在充分权衡各种方案的利弊的

❸ 相关的软件工程国家标准把软件生存周期划分为8个阶段,是那8个阶段

软件工程
软件工程一直以来都缺乏一个统一的定义,很多学者、组织机构都分别给出了自己的定义:

Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。

IEEE:软件工程是开发、运行、维护和修复软件的系统方法。

Fritz Bauer:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。

软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。

(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。

(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。

(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。

软件工程必须遵循什么原则

围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则:

(1)选取适宜的开发模型

该原则与系统设计有关。在系统设计中,软件需求、硬件需求以及其它因素间是相互制约和影响的,经常需要权衡。因此,必需认识需求定义的易变性,采用适当的开发模型,保证软件产品满足用户的要求。

(2)采用合适的设计方法

在软件设计中,通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现,以达到软件工程的目标。

(3)提供高质量的工程支撑

工欲善其事,必先利其器。在软件工程中,软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。

(4)重视软件工程的管理

软件工程的管理直接影响可用资源的有效利用,生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此,仅当软件过程予以有效管理时,才能实现有效的软件工程。

软件工程是指导计算机软件开发和维护的工程学科。

采用工程的概念、原理、 技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来,这就是软件工程。

软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是

在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对

软件产品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策

略就是“各个击破”,也就是对问题进行分解然后再分别解决各个子问题的策略

。软件工程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题

进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立

的任务,然后逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候,

从对任务的抽象逻辑分析开始,一个阶段一个阶段地进行开发。前一个阶段任务

的完成是开始进行后一个阶段工作的前提和基础,而后一阶段任务的完成通常是

使前一阶段提出的解法更进一步具体化,加进了更多的物理细节。每一个阶段的开

始和结束都有严格标准,对于任何两个相邻的阶段而言,前一阶段的结束标准就

是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查

和管理复审,从技术和管理两方面对这个阶段的开发成果进行检查,通过之后这

个阶段才算结束;如果检查通不过,则必须进行必要的返工,并且返工后还要再

经过审查。审查的一条主要标准就是每个阶段都应该交出“最新式的”(即和所

开发的软件完全一致的)高质量的文档资料,从而保证在软件开发工程结束时有

一个完整准确的软件配置交付使用。文档是通信的工具,它们清楚准确地说明了

到这个时候为止,关于该项工程已经知道了什么,同时确立了下一步工作的基础

。此外,文档也起备忘录的作用,如果文档不完整,那么一定是某些工作忘记做

了,在进入生存周期的下一阶段之前,必须补足这些遗漏的细节。在完成生存周

期每个阶段的任务时,应该采用适合该阶段任务特点的系统化的技术方法——结

构分析或结构设计技术。

把软件生存周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简

单,便于不同人员分工协作,从而降低了整个软件开发工程的困难程度;在软件

生存周期的每个阶段都采用科学的管理技术和良好的技术方法,而且在每个阶段

结束之前都从技术和管理两个角度进行严格的审查,合格之后才开始下一阶段的

工作,这就使软件开发工程的全过程以一种有条不紊的方式进行,保证了软件的

质量,特别是提高了软件的可维护性。总之,采用软件工程方法论可以大大提高

软件开发的成功率,软件开发的生产率也能明显提高。

目前划分软件生存周期阶段的方法有许多种,软件规模、种类、开发方式、

开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件

生存周期的阶段时应该遵循的一条基本原则就是使各阶段的任务彼此间尽可能相

对独立,同一阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂程

度,简化不同阶段之间的联系,有利于软件开发工程的组织管理。一般说来,软

件生存周期由软件定义、软件开发和软件维护三个时期组成,每个时期又进一步

划分成若干个阶段。下面的论述主要针对应用软件,对系统软件也基本适用。

软件定义时期的任务是确定软件开发工程必须完成的总目标;确定工程的可行

性,导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程

需要的资源和成本,并且制定工程进度表。这个时期的工作通常又称为系统分析

,由系统分析员负责完成。软件定义时期通常进一步划分成三个阶段,即问题定

义、可行性研究和需求分析。

开发时期具体设计和实现在前一个时期定义的软件,它通常由下述四个阶段组

成:总体设计,详细设计,编码和单元测试,综合测试。

维护时期的主要任务是使软件持久地满足用户的需要。具体地说,当软件在

使用过程中发现错误时应该加以改正;当环境改变时应该修改软件以适应新的环境

;当用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再

进一步划分阶段,但是每一次维护活动本质上都是一次压缩和简化了的定义和开

发过程。

下面扼要介绍软件生存周期每个阶段的基本任务和结束标准。

1问题定义

问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道

问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最

终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的

,但是在实践中它却可能是最容易被忽视的一个步骤。

通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和

规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员

扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份

书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都

满意的文档。

问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的

时间。

2可行性研究

这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解

决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的

系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。

可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范

围,探索这个问题是否值得去解,是否有可行的解决办法。

在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究

阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更

准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效

益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。

可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的

重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进

行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值

得投资的工程项目,可以避免更大的浪费。

3需求分析

这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,

目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。

用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表

达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道

怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统

分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确

认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻

辑模型。

在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因

此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术

专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的

细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结

构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完

整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有

效地防止和克服急于着手进行具体设计的倾向。

4总体设计

这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”

首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用

计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是

人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑

下述几类可能的方案:

低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工

作。

中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用

起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没

有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的

能力在实践中将证明是很有价值的。

高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功

能和特点。

系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种

方案的成本和效益,还应该在充分权衡各种方案的利弊的∩希萍鲆桓鼋虾?nbsp;

的系统(最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分

析员推荐的系统,则可以着手完成本阶段的另一项主要工作。

上面的工作确定了解决问题的策略以及目标系统需要哪些程序,但是,怎样设

计这些程序呢?结构设计的一条基本原理就是程序应该模块化,也就是一个大程

序应该由许多规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二

项主要任务就是设计软件的结构,也就是确定程序由哪些模块组成以及模块间的

关系。通常用层次图或结构图描绘软件的结构。

5详细设计

总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段

的任务就是把解法具体化,也就是回答下面这个关键问题:“应该怎样具体地实现这

个系统呢?”

这个阶段的任务还不是编写程序,而是设计出程序的详细规格说明。这种规

格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图,它们应该

包含必要的细节,程序员可以根据它们写出实际的程序代码。

通常用HIPO图(层次图加输入/处理/输出图)或PDL语言(过程设计语言

)描述详细设计的结果。

6编码和单元测试

这个阶段的关键任务是写出正确的容易理解、容易维护的程序模块。

程序员应该根据目标系统的性质和实际环境,选取一种适当的高级程序设计

语言(必要时用汇编语言),把说细设计的结果翻译成用选定的语言书写的程序

,并且仔细测试编写出的每一个模块。

7综合测试

这个阶段的关键任务是通过各种类型的测试(及相应的调试)使软件达到预定

的要求。

最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构

,把经过单元测试检验的模块按某种选定的策略装配起来,在装配过程中对程

序进行必要的测试。所谓验收测试则是按照规格说明书的规定(通常在需求分析

阶段确定),由用户(或在用户积极参加下)对目标系统进行验收。

必要时还可以再通过现场测试或平行运行等方法对目标系统进一步测试检验。

为了使用户能够积极参加验收测试,并且在系统投入生产性运行以后能够正确

有效地使用这个系统,通常需要以正式的或非正式的方式对用户进行培训。

通过对软件测试结果的分析可以预测软件的可靠性;反之,根据对软件可靠

性的要求也可以决定测试和调试过程什么时候可以结束。

应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下

来,做为软件配置的一个组成成分。

8软件维护

维护阶段的关键任务是,通过各种必要的维护活动使系统持久地满足用户的

需要。

通常有四类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的

软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,

即根据用户的要求改进或扩充软件使它更完善;预防性维护,即修改软件为将来

的维护活动预先做准备。

虽然没有把维护阶段进一步划分成更小的阶段,但是实际上每一项维护活动

都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出

维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,

复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开

发的全过程。

都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出

维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,
复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开
发的全过程。
参考资料:"
还不错,希望你采纳。

❹ 软件工程使用PDL语言(过程设计语言)描述在数组A[1]~A[10]中找出最大数的算法。(图)

Procere 数组找最大值
interface 数组A 数组容量10
begin
declare i as整型
declare max as整型
初始化max等于A[0]
初始化i等于1
loop while i小于10
if A[i]大于max then
将A[i]的值赋给max
end loop
display max的值
end

❺ 软件工程师资格认证(初级)需要看哪些资料

您现在所在位置:首页>>水平考试大纲>>软件工程师考试(初级)大纲
软件工程师考试(初级)大纲
一、考试说明

1.考试要求:

(1)掌握计算机系统的基本知识;

(2)掌握计算机运算和算法的基本知识;

(3)掌握数据结构的基本知识;

(4)理解软件工程方法;

(5)熟悉Windows98操作系统的主要功能和操作;

(6)掌握C语言的程序设计技术;

(7)掌握SQL语言的使用。

2.通过本级水平考试的合格人员具有从事计算机程序编制(程序员)的实际工作能力和业务水平。

3.本级水平考试范围包括三个模块,即模块1、模块2和模块3。题型为单项选择题。每个模块考试时间为90分钟。

二、考试范围

模块1:计算机运算基础

1.1计算机系统

1.1.1计算机系统的基本组成

1.1.2计算机硬件系统

●中央处理器

●内存储器

●外存储器

●输入设备

●输出设备

1.1.3计算机软件系统

●计算机软件及其分类

●操作系统的功能及其分类

●程序设计语言与语言处理程序

1.1.4微型计算机的分类与主要性能指标

●微型计算机的分类

●微型计算机的主要性能指标

1.1.5计算机的特点及其应用

●计算机工作的主要特点

●计算机的主要应用

●计算机的发展方向

1.1.6计算机安全

●微型计算机的使用环境

●微型计算机的维护

●计算机病毒及其防治

1.2计算机计数制

1.2.1数制的基本概念

1.2.2二进制及其运算

●二进制与十进制之间的转换

●二进制数据的算术运算与逻辑运算

1.2.3十六进制与十进制之间的转换

1.2.4八进制与十进制之间的转换

1.2.5各种计算机计数制之间的转换

1.3计算机编码

1.3.1计算机中数的表示

●正负数的表示

●定点数与浮点数

●原码、反码、补码

1.3.2字符编码

1.3.3汉字编码

模块2:软件开发基础

2.1软件工程基本概念

2.1.1软件工程的概念

2.1.2软件生命周期

2.1.3瀑布模型

2.1.4原型法

2.1.5软件工具与软件开发环境

2.2基本数据结构

2.2.1数据结构的基本概念

●什么叫数据结构

●数据结构的存储

2.2.2线性表

●线性表的基本概念

●顺序存储结构下线性表的插入与删除

●线性链表

2.2.3栈

2.2.4队列

2.2.5二叉树

2.3算法

2.3.1算法的基本概念

2.3.2算法的复杂度

●算法的时间复杂度

●算法的空间复杂度

2.3.3常用基本算法

●冒泡排序

●快速排序

●希尔排序

●堆排序

●对分查找

2.4程序设计概念

2.4.1程序设计的基本方法

●结构化设计

●模块化设计

●自顶向下、逐步细化的设计过程

2.4.2程序设计的风格

2.4.3程序的调试

2.5软件详细设计的表达

2.5.1程序流程图

2.5.2NS图

2.5.3问题分析图PAD

2.5.4判定表

2.5.5过程设计语言PDL

2.6文字处理技术

模块3:程序编制基础

3.1C语言编程

3.1.1程序的基本组成

●说明与定义

●数据的输入与输出

●数据的处理

3.1.2选择结构

●两路分支选择

●多路分支选择i

3.1.3循环结构

●当型循环

●直到型循环

●for循环

●循环的嵌套

3.1.4模块设计

●模块的实现——函数

●模块间的参数传递

●模块的递归调用

3.1.5数组

●一维数组

●二维数组

●字符数组

●数组作为函数参数

3.1.6指针

●指针的基本概念

●指针变量

●数组与指针

●字符串与指针

●指针数组与指向指针的指针

●函数与指针

3.1,7结构体

●结构体类型变量

●结构体数组

●结构体与指针

●关于结构体的其它说明

3.1.8文件

●文件的概念

●文件的打开与关闭

●文件的读写

●文件的定位

3.2Windows98中文版操作系统

3.2.1了解Windows98中文版操作系统

3.2.2配置Windows98中文版操作系统

3.2.3Windows98的基本操作

3.2.4Windows98资源管理器

3.3关系数据库语言SQL

3.3.1数据库的基本概念

3.3.2SQL语言概要

●SQL语言的功能与特点

●SQL的数据类型

●SQL的语句结构

●SQL的命令分类

3.3.3数据库定义

●表、视图和索引

●表的建立、修改和删除

●视图的建立、修改和删除

●索引的建立和删除

3.3.4数据查询

●单表查询

●多表查询

●附加子句

●视图的查询

3.3.5数据修改

●数据的输入

●数据的修改

●数据的删除

●视图的修改

3.3.6SQL数据控制

3.3.7嵌入式SQL

●不用游标的DML语句

●使用游标的DML语句

❻ 软件工程概论主要的体系结构框架有哪些

软件工程的基本概念、软件生存周期与软件过程、结构化软件分析(需求工程)、结构化软件设计、面向对象软件工程、面向对象分析、面向对象设计、编码与测试、软件维护、软件复用、 软件工程管理、软件质量管理、软件工程环境等。
第一章 软件工程概述
第一节软件危机与软件工程
知识点:软件危机形成的原因;软件工程的概念、原理;
第二节软件过程
知识点:软件生命周期及软件开发的各个模型;
第二章 可行性研究
第一节可行性研究的任务
知识点:可行性分析的步骤及方法;
第二节数据流图及数据字典
知识点:系统流程图及数据流图的画法;数据字典的定义方法;
第三章 需求分析

第一节需求分析的任务
知识点:需求的重要性;获取需求的方法;
第二节图形工具
知识点:实体联系图;状态转换图;层次方框图;
第四章 概要设计

第一节设计原理
知识点:设计原理;启发规则;
第二节面向数据流的设计方法
知识点:变换分析;事务分析;
第五章 详细设计

第一节过程设计的工具
知识点:程序流程图;N-S图;PAD图;PDL;
第二节程序复杂程度的定量度量
知识点:McCabe方法;Halstead方法;
第六章 面向对象的分析与设计方法

第一节面向对象分析
知识点:统一建模语言;三大模型;
第二节面向对象设计
知识点:面向对象设计准则;面向对象设计模型;
第七章 编码与实现

第一节编码与实现
知识点:编程语言的选择;编码原则;
第二节调试与维护
知识点:调试;软件可靠性;软件维护;
第八章 软件质量与质量保证

第一节软件测试技术
知识点:各种测试的概念;白盒测试;黑盒测试;
第二节质量保证
知识点:软件质量要素;质量保证措施;

❼ 软件工程 考试 求助

CBCDD DDACC DBBCD

2. 系统必须做什么
3.外部实体 数据处理 数据存储 数据流
5.象 类 继承
6.单元测试

❽ 关于软件工程这门课程

软件工程一直以来都缺乏一个统一的定义,很多学者、组织机构都分别给出了自己的定义:

Boehm:运用现代科学技术知识来设计并构造计算机程序及为开发、运行和维护这些程序所必需的相关文件资料。

IEEE:软件工程是开发、运行、维护和修复软件的系统方法。

Fritz Bauer:建立并使用完善的工程化原则,以较经济的手段获得能在实际机器上有效运行的可靠软件的一系列方法。

软件工程学的内容
软件工程学的主要内容是软件开发技术和软件工程管理.
软件开发技术包含软件工程方法学、软件工具和软件开发环境;软件工程管理学包含软件工程经济学和软件管理学。

软件工程基本原理

著名软件工程专家B.Boehm综合有关专家和学者的意见并总结了多年来开发软件的经验,于1983年在一篇论文中提出了软件工程的七条基本原理。
(1)用分阶段的生存周期计划进行严格的管理。
(2)坚持进行阶段评审。
(3)实行严格的产品控制。
(4)采用现代程序设计技术。
(5)软件工程结果应能清楚地审查。
(6)开发小组的人员应该少而精。
(7)承认不断改进软件工程实践的必要性。
B.Boehm指出,遵循前六条基本原理,能够实现软件的工程化生产;按照第七条原理,不仅要积极主动地采纳新的软件技术,而且要注意不断总结经验。
软件工程(SoftWare Engineering)的框架可概括为:目标、过程和原则。
(1)软件工程目标:生产具有正确性、可用性以及开销合宜的产品。正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。
(2)软件工程过程:生产一个最终能满足需求且达到工程目标的软件产品所需要的步骤。软件工程过程主要包括开发过程、运作过程、维护过程。它们覆盖了需求、设计、实现、确认以及维护等活动。需求活动包括问题分析和需求分析。问题分析获取需求定义,又称软件需求规约。需求分析生成功能规约。设计活动一般包括概要设计和详细设计。概要设计建立整个软件系统结构,包括子系统、模块以及相关层次的说明、每一模块的接口定义。详细设计产生程序员可用的模块说明,包括每一模块中数据结构说明及加工描述。实现活动把设计结果转换为可执行的程序代码。确认活动贯穿于整个开发过程,实现完成后的确认,保证最终产品满足用户的要求。维护活动包括使用过程中的扩充、修改与完善。伴随以上过程,还有管理过程、支持过程、培训过程等。
(3)软件工程的原则是指围绕工程设计、工程支持以及工程管理在软件开发过程中必须遵循的原则。

软件工程必须遵循什么原则

围绕工程设计、工程支持以及工程管理已提出了以下四条基本原则:

(1)选取适宜的开发模型

该原则与系统设计有关。在系统设计中,软件需求、硬件需求以及其它因素间是相互制约和影响的,经常需要权衡。因此,必需认识需求定义的易变性,采用适当的开发模型,保证软件产品满足用户的要求。

(2)采用合适的设计方法

在软件设计中,通常需要考虑软件的模块化、抽象与信息隐蔽、局部化、一致性以及适应性等特征。合适的设计方法有助于这些特征的实现,以达到软件工程的目标。

(3)提供高质量的工程支撑

工欲善其事,必先利其器。在软件工程中,软件工具与环境对软件过程的支持颇为重要。软件工程项目的质量与开销直接取决于对软件工程所提供的支撑质量和效用。

(4)重视软件工程的管理

软件工程的管理直接影响可用资源的有效利用,生产满足目标的软件产品以及提高软件组织的生产能力等问题。因此,仅当软件过程予以有效管理时,才能实现有效的软件工程。

软件工程是指导计算机软件开发和维护的工程学科。

采用工程的概念、原理、 技术和方法来开发与维护软件,把经过时间考验而证明正确的管理技术和当前能够 得到的最好的技术方法结合起来,这就是软件工程。

软件工程强调使用生存周期方法学和各种结构分析及结构设计技术。它们是在七十年代为了对付应用软件日益增长的复杂程度、漫长的开发周期以及用户对软件产品经常不满意的状况而发展起来的。人类解决复杂问题时普遍采用的一个策略就是“各个击破”,也就是对问题进行分解然后再分别解决各个子问题的策略。软件工程采用的生存周期方法学就是从时间角度对软件开发和维护的复杂问题进行分解,把软件生存的漫长周期依次划分为若干个阶段,每个阶段有相对独立的任务,然后逐步完成每个阶段的任务。采用软件工程方法论开发软件的时候,从对任务的抽象逻辑分析开始,一个阶段一个阶段地进行开发。前一个阶段任务的完成是开始进行后一个阶段工作的前提和基础,而后一阶段任务的完成通常是使前一阶段提出的解法更进一步具体化,加进了更多的物理细节。每一个阶段的开始和结束都有严格标准,对于任何两个相邻的阶段而言,前一阶段的结束标准就是后一阶段的开始标准。在每一个阶段结束之前都必须进行正式严格的技术审查和管理复审,从技术和管理两方面对这个阶段的开发成果进行检查,通过之后这个阶段才算结束;如果检查通不过,则必须进行必要的返工,并且返工后还要再经过审查。审查的一条主要标准就是每个阶段都应该交出“最新式的”(即和所开发的软件完全一致的)高质量的文档资料,从而保证在软件开发工程结束时有一个完整准确的软件配置交付使用。文档是通信的工具,它们清楚准确地说明了到这个时候为止,关于该项工程已经知道了什么,同时确立了下一步工作的基础。此外,文档也起备忘录的作用,如果文档不完整,那么一定是某些工作忘记做了,在进入生存周期的下一阶段之前,必须补足这些遗漏的细节。在完成生存周期每个阶段的任务时,应该采用适合该阶段任务特点的系统化的技术方法——结构分析或结构设计技术。

把软件生存周期划分成若干个阶段,每个阶段的任务相对独立,而且比较简单,便于不同人员分工协作,从而降低了整个软件开发工程的困难程度;在软件生存周期的每个阶段都采用科学的管理技术和良好的技术方法,而且在每个阶段结束之前都从技术和管理两个角度进行严格的审查,合格之后才开始下一阶段的工作,这就使软件开发工程的全过程以一种有条不紊的方式进行,保证了软件的质量,特别是提高了软件的可维护性。总之,采用软件工程方法论可以大大提高软件开发的成功率,软件开发的生产率也能明显提高。

目前划分软件生存周期阶段的方法有许多种,软件规模、种类、开发方式、开发环境以及开发时使用的方法论都影响软件生存周期阶段的划分。在划分软件生存周期的阶段时应该遵循的一条基本原则就是使各阶段的任务彼此间尽可能相对独立,同一阶段各项任务的性质尽可能相同,从而降低每个阶段任务的复杂程度,简化不同阶段之间的联系,有利于软件开发工程的组织管理。一般说来,软件生存周期由软件定义、软件开发和软件维护三个时期组成,每个时期又进一步划分成若干个阶段。下面的论述主要针对应用软件,对系统软件也基本适用。

软件定义时期的任务是确定软件开发工程必须完成的总目标;确定工程的可行性,导出实现工程目标应该采用的策略及系统必须完成的功能;估计完成该项工程需要的资源和成本,并且制定工程进度表。这个时期的工作通常又称为系统分析,由系统分析员负责完成。软件定义时期通常进一步划分成三个阶段,即问题定义、可行性研究和需求分析。

开发时期具体设计和实现在前一个时期定义的软件,它通常由下述四个阶段组成:总体设计,详细设计,编码和单元测试,综合测试。

维护时期的主要任务是使软件持久地满足用户的需要。具体地说,当软件在使用过程中发现错误时应该加以改正;当环境改变时应该修改软件以适应新的环境;当用户有新要求时应该及时改进软件满足用户的新需要。通常对维护时期不再进一步划分阶段,但是每一次维护活动本质上都是一次压缩和简化了的定义和开发过程。

下面扼要介绍软件生存周期每个阶段的基本任务和结束标准。

1问题定义

问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的,但是在实践中它却可能是最容易被忽视的一个步骤。

通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都满意的文档。

问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的时间。

2可行性研究

这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。

可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范围,探索这个问题是否值得去解,是否有可行的解决办法。

在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。

可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值得投资的工程项目,可以避免更大的浪费。

3需求分析

这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。

用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻辑模型。

在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有效地防止和克服急于着手进行具体设计的倾向。

4总体设计

这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”

首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑下述几类可能的方案:

低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工作。

中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的能力在实践中将证明是很有价值的。

高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功能和特点。

系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种方案的成本和效益,还应该在充分权衡各种方案的利弊的基础上,推荐一个较好的系统 (最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分析员推荐的系统,则可以着手完成本阶段的另一项主要工作。

上面的工作确定了解决问题的策略以及目标系统需要哪些程序,但是,怎样设计这些程序呢?结构设计的一条基本原理就是程序应该模块化,也就是一个大程序应该由许多规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二项主要任务就是设计软件的结构,也就是确定程序由哪些模块组成以及模块间的关系。通常用层次图或结构图描绘软件的结构。

5详细设计

总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段的任务就是把解法具体化,也就是回答下面这个关键问题:“应该怎样具体地实现这个系统呢?”

这个阶段的任务还不是编写程序,而是设计出程序的详细规格说明。这种规格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图,它们应该包含必要的细节,程序员可以根据它们写出实际的程序代码。

通常用HIPO图(层次图加输入/处理/输出图)或PDL语言(过程设计语言)描述详细设计的结果。

6编码和单元测试

这个阶段的关键任务是写出正确的容易理解、容易维护的程序模块。

程序员应该根据目标系统的性质和实际环境,选取一种适当的高级程序设计语言(必要时用汇编语言),把说细设计的结果翻译成用选定的语言书写的程序,并且仔细测试编写出的每一个模块。

7综合测试

这个阶段的关键任务是通过各种类型的测试(及相应的调试)使软件达到预定的要求。

最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构,把经过单元测试检验的模块按某种选定的策略装配起来,在装配过程中对程序进行必要的测试。所谓验收测试则是按照规格说明书的规定(通常在需求分析阶段确定),由用户(或在用户积极参加下)对目标系统进行验收。

必要时还可以再通过现场测试或平行运行等方法对目标系统进一步测试检验。

为了使用户能够积极参加验收测试,并且在系统投入生产性运行以后能够正确有效地使用这个系统,通常需要以正式的或非正式的方式对用户进行培训。

通过对软件测试结果的分析可以预测软件的可靠性;反之,根据对软件可靠性的要求也可以决定测试和调试过程什么时候可以结束。

应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下来,做为软件配置的一个组成成分。

8软件维护

维护阶段的关键任务是,通过各种必要的维护活动使系统持久地满足用户的需要。

通常有四类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,即根据用户的要求改进或扩充软件使它更完善;预防性维护,即修改软件为将来的维护活动预先做准备。

虽然没有把维护阶段进一步划分成更小的阶段,但是实际上每一项维护活动都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。

都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。

❾ 软件工程问题解答

chuan nong de .zhe ke lao shi zhen de~~~

与pdl语言软件工程相关的资料

热点内容
苏州假山景观设计工程 浏览:862
哈尔滨工程造价招聘 浏览:937
建筑工程土建劳务分包 浏览:632
道路监理工程师 浏览:476
安徽工程大学机电学院在本校吗 浏览:370
河北工程大学保研率多少 浏览:287
有学质量工程师的书吗 浏览:479
康乐县建筑工程公司 浏览:569
助理工程师二级 浏览:872
注册安全工程师初级考试时间 浏览:901
食品科学与工程专业课题研究 浏览:881
工程造价图纸建模 浏览:888
辽宁恒润建设工程有限公司 浏览:93
实行施工总承包的工程项目 浏览:737
道路桥梁工程技术兴趣爱好 浏览:316
密歇根理工大学电气工程专业 浏览:388
广西交通工程质量监督站 浏览:31
四川大学材料科学与工程学院考研参考书目 浏览:858
有线电视工程建设管理条例 浏览:270
云南工程监理公司排名 浏览:673