软件开发流程软件开发流程概述项目:需求来自某个别用户,定制性能政府、企业、基金项目金土资源、myPKI产品:需求来自某类用户,不单独定制Windows立项阶段开发阶段维护阶段市场调研立项申请需求分析总体设计详细设计编码文档单元测试集成测试系统测试产品化发行结项产品维护个性化修改软件产品开发流程1、可行性分析——做不做?目的:为决策提供依据要求:真实、全面与重点兼顾内容:市场可行性:成熟?对手?用户?政策可行性:盗版软件?技术可行性:核心技术?时间?成本收益分析:办公、工资、培训、维护SWOT分析:-Strengths,Weaknesses,Opportunities,ThreatsSWOT分析Strengths技术技能优势:资产优势:有形(先进设施)、无形(品牌)人力资源优势:组织体系优势竞争能力:开发周期,营销网络Weaknesses缺乏核心技能技术?缺乏有竞争力的资产资源(包括人力)……Opportunities确认评价每个重要机会客户群的扩展市场壁垒并购竞争对手?向其他地理区域扩张?Threats市场内的竞争对手市场增值率汇率和外贸政策市场需求减少经济危机,国家调控政策2、需求分析——有所为有所不为重要性:难点:用户需求不断改变、交流理解有误差内容:功能需求性能指标环境需求:软、硬件环境界面需求:人机交互方式使用工具:RationalRose、Visio3、系统设计——架构师软件体系结构属于系统设计可分两个阶段:总体设计和详细设计总体设计:需求分析的结果——软件体系构架、结构复杂系统模块进行功能划分、建立层次结构详细设计:各个模块的功能设计3、系统设计——流程总体设计评审软件体系结构修改需求说明书详细设计接受评审系统设计说明书修改模块功能描述3、系统设计——内容需求分析软件体系结构设计界面设计数据库设计模块功能设计算法、数据结构设计编码测试总体设计详细设计系统设计系统设计——用户界面设计用户界面类型对话框:计算器文档:office浏览器:outlook其他,如游戏界面界面设计人机界面就是系统本身3、系统设计——界面设计原则实用、直观、简洁、生动对用户友好:符合习惯、及时反馈信息风格一致:WordPowerpoint错误处理:提示、撤销等帮助:尽量减少非必要信息3、系统设计——数据库设计目的:设计表结构存储、操作数据步骤,分两步:抽象:客观对象抽象出实体和联系模型-Entity-Relationship将(概念)模型转化为实际数据库系统支持的数据模型(物理模型)数据库设计范式1NF、2NF、3NF、BCNF使得添加、更新、删除时少发生错误工具:PowerDesigner系统设计——数据库设计方法和工具1ER图实体:□,例如学生、教师属性:○,学生属性:姓名、性别、学号关系:◇,实体间关系课程学号分数学生成绩学号性别姓名班级n课程选修院系4、模块设计模块指系统的各功能部件模块化降低开发、测试、维护的代价如何划分模块:没有标准答案模块设计的原则接口公开、内部实现隐藏高内聚:模块内部关联度高。如果不高?低耦合:模块之间依赖程度应该低。高?模块设计内容接口(外)、数据结构+算法(内)4、模块设计——OOP设计类的抽象类的结构层次:继承、依赖类的属性、定义类的实现5、模块设计——数据结构和算法设计理念为那种应用服务?时间优先还是空间优先?熟悉哪些算法或数据结构一般过程先设计全局数据结构、再局部数据结构优先使用已有、成熟、合适的,再考虑自行设计满足性能即可,不满足,再优化6、编码语言Java:面向对象、分布式、解释型、可移植、多线程,.Net:健壮、安全、统一、开发简单-CLR(CommonLanguageRuntime):核心,类似虚拟机,负责代码执行、内存管理、安全等-Framework:平台基础-C#,C++,…Unix/LinuxCLRNativeImageGenerator(NGEN)6、编码——编码规范目标:易读、风格统一、安全,可维护移植内容:命名代码书写格式其他如函数、变量等的设置要求6、编码——开发方法一种软件开发方法:极限编程XP(eXtremeProgramming)KentBeck:1996理念:交流、朴素、反馈、勇气、尊重将复杂的开发过程分解为许多相对简单的小周期。积极交流反馈,让涉众清楚开发进度、问题、困难,并及时调整。相互尊重!极限:把所有强调的思想、方法做到最好,其他忽略;RUPAgileScrum6、编码——源代码控制版本管理人员离开变动?如何记录重要更新?多个版本出现,管理版本的变化?对各个小组的子模块管理?保留修改轨迹,便于撤销错误的改动?常用工具:VSS,MicrosoftVisualSouceSafeCVS,ConcurrentVersionsSystem,-Opensource7、软件测试定义(Myers,软件测试艺术):为了发现错误而执行程序的过程目的:保证软件质量时机:在软件交付用户或投入运行之前经验:错误越迟被发现,调试难度越大。阶段:单元测试、集成测试、系统测试、用户测试7、软件测试单元测试由开发者编写一段代码,检验程序基本功能是否正确。测试的单元:类、函数。-例如装配电脑,先测试显卡、硬盘、光驱等7、软件测试集成测试:自顶向下桩模块:模拟真模块,提供数据建立测试驱动模块:以程序真正的主模块为驱动模块,替换某桩模块,输入数据,检测输出是否正确回归测试:做一定修改后,再次由测试部门进行测试结束测完所有模块?Y回归测试替换一个桩模块建立测试驱动模块建立桩模块开始N集成测试7、软件测试集成测试:自底向上组织模块群:将部分底层模块组装成实现某个功能的模块群建立测试驱动模块:对上一步组装的模块群开发一个测试程序,输入数据,测试输出是否正确结束测完所有模块?Y删除驱动模块测试模块群建立测试驱动模块组织模块群开始N7、软件测试——系统测试概念:将完整的软件及其所依赖的软硬件环境整合,进行测试内容:性能、负载黑盒测试:不关心内部,只看结果是否正确白盒测试:结构或逻辑测试,检验内部功能是否按规定正确工作。单元测试通常是白盒测试,而集成测试和系统测试往往是黑盒测试7、软件测试——测试工具单元测试:xUnit(CppUnit,Junit,Nunit)黑盒:功能测试:RationalSQARobot性能测试:RationalSQALoad白盒测试:内存泄露:RationalPurify代码覆盖率:RationalPurecoverage代码性能:RationalQuantify测试管理:RationalTestManager8、结项安装盘的制作InstallShield,Acresso公司,事实标准VisioStudio.Net发布程序版权保护加密:序列号说明书帮助文档制作HLP,早期,MicrosoftHelpWorkshopCHM,1998年推出,MicrosoftHtmlHelpWorkshop8、软件维护未发现的Bug需求改变版本升级兼容售后培训……DimensionsofsoftwarecomplexityHighertechnicalcomplexity-Embedded,real-time,distributed,fault-tolerant-Custom,unprecedented,architecturereengineering-HighperformanceLowertechnicalcomplexity-Mostly4GL,orcomponent-based-Applicationreengineering-InteractiveperformanceHighermanagementcomplexity-Largescale-Contractual-Manystakeholders-“Projects”Lowermanagementcomplexity-Smallscale-Informal-Singlestakeholder-“Products”DefenseMISSystemDefenseWeaponSystemTelecomSwitchCASEToolNationalAirTrafficControlSystemEnterpriseIS(FamilyofISApplications)CommercialCompilerBusinessSpreadsheetISApplicationDistributedObjects(OrderEntry)SmallScientificSimulationLarge-ScaleOrganization/EntitySimulationAnaveragesoftwareproject:-5-10people-10-15monthduration-3-5externalinterfaces-Someunknowns&risksEmbeddedAutomotiveSoftwareISApplicationGUI/RDB(OrderEntry)CASE:computeraidedsoftwareengineeringForcesinSoftwareTechnologychurnOurenemyiscomplexity,andit’sourgoaltokillit.——JanBaanPerformanceThroughputCapacityAvailabilityFailsafeFaulttoleranceFunctionalityCostCompatibilityResilienceThechallengeoverthenext20yearswillnotbespeedorcostorperformance;itwillbeaquestionofcomplexity.——BillRaduchel,ChiefStrategyOfficer,SunMicrosystems