信息系统开发基础课件.ppt
《信息系统开发基础课件.ppt》由会员分享,可在线阅读,更多相关《信息系统开发基础课件.ppt(93页珍藏版)》请在三一办公上搜索。
1、第二章 信息系统开发基础,谭火彬,Fundamentals of Information Systems Development,北京航空航天大学软件学院 thbin,2,课程资源,联系老师办公地点:6#323联系电话:82338867Email:课件下载学院ftp服务器地址:ftp:/202.112.128.79u/p:bse2002/3221Web下载http:/,北京航空航天大学软件学院 thbin,3,复习:系统分析设计基础,北京航空航天大学软件学院 thbin,4,选择题,信息系统开发过程涉及到的项目干系人,(1)提供软件需求;(2)定义项目范围;(3)设计软件总体结构A.系统拥有者
2、B.系统用户C.系统分析师D.系统设计人员E.系统构造人员F.IT厂商和顾问,北京航空航天大学软件学院 thbin,5,信息系统开发的核心技术,系统开发过程过程是为到达目的采用的一系列步骤用于信息系统和软件的开发和维护的一组活动、方法、实践、发布、及自动化工具系统开发方法为系统开发提供了“如何做”的技术系统开发工具为系统开发提供了自动的或半自动的支撑环境,北京航空航天大学软件学院 thbin,6,内容安排,系统开发生命周期系统开发过程过程评价准则系统开发方法自动化工具和技术,北京航空航天大学软件学院 thbin,7,内容安排,系统开发生命周期系统开发过程过程评价准则系统开发方法自动化工具和技术
3、,北京航空航天大学软件学院 thbin,8,系统开发项目,系统开发项目一个有始有终的任务产生预先确定的结果或产品可以是一个大工程,需要许多人进行数千小时的工作;也可以是一个很小的项目成功的项目详细的计划有组织的讲究方法的一系列活动和任务可靠、强大而高效的信息系统,北京航空航天大学软件学院 thbin,9,系统开发生命周期,系统开发生命周期(SDLC,System Development Lifecycle)把一个项目较简单地组成各个阶段提供了确保成功开发所需要的结构、方法、控制和核对表包含管理原则、计划、组织、问题解决协调、控制、分工、进度安排等问题,北京航空航天大学软件学院 thbin,10
4、,生命周期中的各个阶段,北京航空航天大学软件学院 thbin,11,计划阶段(Planning Phase),目标:规划项目范围并做出项目计划活动定义问题确定项目可行性制定项目的进度表为项目安排人员启动项目,北京航空航天大学软件学院 thbin,12,分析阶段(Analysis Phase),目标:了解并详述用户需求活动收集信息确定系统需求建立需求发现的原型划分需求的优先级产生并评估可替换方案与管理人员一起审查需求,北京航空航天大学软件学院 thbin,13,设计阶段(Design Phase),目标:设计系统解决方案活动设计应用程序结构设计用户界面设计并集成数据库设计系统的实现细节设计并集成
5、网络设计并集成系统控制逻辑,北京航空航天大学软件学院 thbin,14,实现阶段(Implementation Phase),目标:建立、测试和安装最后的系统活动构造软件构件验证与测试移植数据准备用户文档培训用户安装系统,北京航空航天大学软件学院 thbin,15,支持阶段(Support Phase),目标:在系统初始安装后保持系统有效地运行活动提供对最终用户的支持维护和升级系统,北京航空航天大学软件学院 thbin,16,各阶段人员配置情况,北京航空航天大学软件学院 thbin,17,内容安排,系统开发生命周期系统开发过程过程评价准则系统开发方法自动化工具和技术,北京航空航天大学软件学院
6、thbin,18,从SDLC到开发过程,SDLC定义了系统开发的五个阶段阶段并不一定是线性的可以按照合适的方式组织实际的过程系统开发过程针对项目的实际情况,结合SDLC定义合适的过程完成项目开发系统开发过程由关于系统的阶段、状态、方法、技术和开发、维护软件的人员以及相关对象(计划、文档、模型、编码、测试、手册等)组成,北京航空航天大学软件学院 thbin,19,以过程为核心组织软件工程,北京航空航天大学软件学院 thbin,20,过程中的事件、阶段、活动和任务,北京航空航天大学软件学院 thbin,21,典型的软件系统开发过程,传统系统开发过程1.编码修正模型2.瀑布模型3.螺旋模型4.原型模
7、型现代软件工程过程5.Rational统一过程(RUP)6.敏捷过程(AP)7.微软解决方案(MSF),北京航空航天大学软件学院 thbin,22,1.编码修正模型,编码修正模型(Code and Fix)从一个大致的想法开始工作,然后经过非正规的设计、编码、调试和测试方法,最后完成工作,可能有可能没有的规范,发布(可能),北京航空航天大学软件学院 thbin,23,细说编码修正模型,优点成本可能很低只需要很少的专业知识,任何写过程序的人都可以对于一些非常小的、开发完后就会很快丢弃的软件可以采用对于规模稍大的项目,采用这种模型是很危险的,北京航空航天大学软件学院 thbin,24,2.瀑布模型
8、,北京航空航天大学软件学院 thbin,25,细说瀑布模型,瀑布模型最早提出,所有过程模型的祖宗项目从开始到结束按照一定的顺序执行使用里程碑来界定一个阶段到另一阶段的转变文档驱动的,各个阶段不连续也不交叉主要问题线性的、缺乏灵活性;每个阶段互相独立而且不能回退如:必须在项目开始前说明全部需求,北京航空航天大学软件学院 thbin,26,3.螺旋模型,北京航空航天大学软件学院 thbin,27,细说螺旋模型,特点以风险为导向的生命期模型从一个小范围的关键中心地带开始寻找风险因素,制定风险控制计划,并交付给下一步骤,如此迭代,每次迭代将项目扩展到一个更大的规模优势随着迭代的增加(成本的增加),风险
9、程度随之降低缺陷比较复杂,需要责任心,专注和管理方面的知识,北京航空航天大学软件学院 thbin,28,4.原型模型,北京航空航天大学软件学院 thbin,29,细说原型模型,原型模型是一种解决需求的不确定性和可变性的好办法原型是项目系统中的一个方面或者多个方面的工作模型抛弃型原型:用于试验某些概念,试验完系统将无用处演进型原型:原型系统不断被开发和被修正,最终它变为一个真正的系统,北京航空航天大学软件学院 thbin,30,从另外的角度看待原型,从中学到什么?学生经常会做一些软件作业,这些作业被称为原型问题:这些原型和软件系统原型是否相同?作为一个原型必须:描述他们希望从中学到的东西,规划原
10、型评价的方法,报告从原型中真正学到的内容在不同的阶段,原型具有不同的作用原型起作用的程度实物模型(Mock-ups)仿真交互部分模型:水平,垂直(某些特性构造详细的原型),北京航空航天大学软件学院 thbin,31,练习:何时引入原型系统,公司的经理需要通过个人计算机上的一个系统来访问管理信息。系统价格必须合适。很多人怀疑是否经理真需要使用该系统可行性研究阶段,采用实物模型的方法支持客户销售人员通过电话回答有关客户询问汽车保险价格的系统设计用户对话界面时保险公司考虑实施一个基于MS Access的电话销售系统,他们不知道Access是否能够开发出相应界面的系统并具备足够快的相应时间方案设计阶段
11、,北京航空航天大学软件学院 thbin,32,5.Rational统一过程,北京航空航天大学软件学院 thbin,33,Rational统一过程,Rational统一过程(Rational Unified Process,RUP)是一种软件工程过程,它提供了如何在开发组织中严格分配任务和职责的方法是一个过程产品有自己的过程框架捕获了现代软件开发中的最佳实践目标按照预先制定的时间计划和经费预算,开发出高质量的软件产品以满足最终用户的需求,北京航空航天大学软件学院 thbin,34,RUP4个阶段9大工作流,阶段初始Inception生命周期目标精化Elaboration生命周期构架构造Const
12、ruction最初运作能力移交(Transition)产品发布,工作流业务建模需求分析与设计实现测试部署配置和变更管理项目管理环境,北京航空航天大学软件学院 thbin,35,RUP中的6项最佳实践,北京航空航天大学软件学院 thbin,36,RUP三大特点,RUP三大特点用例驱动(Use case driven)以架构为中心(Architecture-centric)迭代和增量开发(Iterative and incremental development),北京航空航天大学软件学院 thbin,37,6.敏捷过程(Agile Process),敏捷代表着有效和灵活那些轻型的、有效的方法即为
13、敏捷方法在重型方法(如RUP)中,经常在一些不必要、重复的中间环节上浪费了太多的精力,而敏捷则避免了这种浪费敏捷联盟宣言Individuals and interactions over processes and toolsWorking software over comprehensive documentationCustomer collaboration over contract negotiationResponding to change over following a plan,北京航空航天大学软件学院 thbin,38,极限编程,客户作为团队成员用户故事短交互周期验收测
14、试结对编程测试驱动的开发方法集体所有权,持续集成可持续的开发速度开放的工作空间计划游戏简单设计重构隐喻,极限编程(eXtreme Programming,XP)是敏捷方法中最著名的一个,它由一系列简单却互相依赖的实践组成,北京航空航天大学软件学院 thbin,39,过程裁剪,裁剪(Tailoring):每个项目自身特点这些过程标准只是一个通用的过程框架,需要根据实际情况裁剪裁剪分类过程裁剪、阶段裁剪、文档/产品/工作产品裁剪标准点项目规模、开发过程(生命周期)、项目类型,北京航空航天大学软件学院 thbin,40,案例:选择合适的过程模型,Giga-Safe公司的区域代理商们吵吵嚷嚷地想要升级
15、Giga-Quote 1.0,改正错误并且修改一些令人厌烦的用户界面上的小问题。在部门经理Randy的建议下,Giga-Quote 1.0项目后期被调离的Bill又重新当上了Giga-Quote 1.1项目的项目经理。“这些就是你的任务。”Randy说。“上次的进度安排出现了很多问题,所以这次你必须按全力以赴的速度来组织项目。原型法是速度最快的方法,让你的团队采用这种方法。”Bill想想觉得挺不错,过几天开会时,他告诉大家要采用原型法。,北京航空航天大学软件学院 thbin,41,案例(续1),Mike是项目的技术负责人,他觉得很惊讶。“Bill,我不同意你的想法”,他说道,“我们有6个星期来
16、修改一系列的错误,而且只是用户界面作一些小的改变。你用原型干什么呢?”“我们需要采用一个原型来提高项目开发速度,”Bill暴躁地说。“原型法是最新、最快的方法,这就足为什么我要求你采用的原因。还有什么问题吗?”“好吧,”Mike说道,“如果那就是你想要的,我们会去开发一个原型。”,北京航空航天大学软件学院 thbin,42,案例(续2),Mike和另外一个开发人员,Sue,开始做原型。因为和他们做的现有系统几乎一样,没几天就做出了整个系统的仿制品。在第2周一上班,他们给代理商经理Jack演示了原型。“该死!我怎么能告诉我的区域代理们要用这个东西!”Jack大声叫道。“和现在的程序相比几乎没有什
17、么改进!我的区域代理们只不过想要更好用,我对一些新的报表有点想法而已。就在这儿,我给你们看看。”Mike和Sue耐心地听着,开完会,Mike 找到了Bill。,北京航空航天大学软件学院 thbin,43,案例(续3),“我们给Jack演示了原型。他想增加一些新的报表,而且很坚决。可是我们的工作计划都安排满了。”“我看不成问题。”Bill说。“他是经理。如果他说要这些报表,他们就肯定是需要的。你们这些家伙该做的就是想想办法怎么给他们按时做出来。”“我试试看吧,”Mike说,“但是我得告诉你的是,如果增加这些报表,我们按时完成任务的机会只有1。”“好吧,你们反正得做,”Bill说,“也许现在采用了
18、原型,工作进展会比你预期的要快。”,北京航空航天大学软件学院 thbin,44,案例(续4),两天后,Jack去了Mike的办公室。“我看了那个原型,我想我们还得增加一些数据录入窗口。我昨天在每月的地区代理例会上给我们的一些代理看了你们做的原型。他们说有些想法得和你谈谈。我给了他们你的电话号码,希望你别介意。”后来,Mike问Bill是否该和Jack谈谈变更的问题,但是Bill说:“不用。”第二天,Mike接到了两个参加了地区代理例会的代理的电话。他们都想再调整一下系统。接下来的2星期里,他每天接到电话,需要修改的内容累积了一大堆。,北京航空航天大学软件学院 thbin,45,案例(续5),他
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 信息系统 开发 基础 课件
链接地址:https://www.31ppt.com/p-3691407.html