博客班级 | 班级链接 |
---|---|
作业要求 | 作业要求链接 |
作业目标 | 了解软件开发文档的知识以及相关工具使用 |
学号 | 3180701115 |
一.实验目的
(1)掌握结构化的需求分析方法;
(2)掌握分层数据流图的绘制、数据字典和加工说明的编制;
(3)掌握数据流图映射为软件结构图的方法;
(4)掌握需求说明书和设计说明。书的主要内容,学习软件需求说明书和设计说明书的编写;
(5)掌握测试的基本方法。
二.实验内容
(1)参考一个熟悉的系统,如,机票预订系统/教材订购系统/ATM自动取款机,讨论其用户需求、系统需求和业务需求;
(2)绘制系统的分层数据流图,并给出数据字典;
(3)将系统的分层数据流图映射为软件结构图,绘制软件结构图;
(4)为关键模块进行详细设计,如绘制关键模块的流程图;
(5)实现系统部分功能并测试。
【实例1】机票预订系统
参考:
(1)携程网:https://flights.ctrip.com/international/search/domestic
(2)去哪儿:https://www.qunar.com/?ex_track=auto_4e0d874a
为了方便旅客,某航空公司拟开发一个机票预定系统。旅行社把预定机票的旅客信息(姓名、性别、工作单位、身份证号码、旅行
时间、旅行目的地等)输入该系统,系统为旅客安排航班,旅客在飞机起飞前一天凭取票通知和账单交款取票,系统核对无误即印出
机票给顾客
【实例2】教材订购系统
销售系统的工作过程为:首先由教师或学生提交购书单,经教材发行人员审核是有效购书单后,开发票、登记并返给教师或学生领
书单,教师或学生即可去书库领书。
采购系统的主要工作过程为:若是脱销教材,则登记缺书,发缺书单给书库采购人员;一旦新书入库后,即发进书单通知给教材发
行人员。
【实例3】图书管理系统
参考:http://lib.ahpu.edu.cn/
三.实验步骤
(1)复习结构化的分析与设计方法的主要过程;
(2)讨论系统存在的用户角色、工作流等;
(3)对关键功能绘制数据流图,给出数据字典,并反复讨论数据流的合理性;
(4)对应数据流图,设计系统的功能结构图,关键模块的流程图;
(5)选择对应的结构化程序设计语言,实现并测试部分功能模块
1.需求分析
1.用户需求
教材订购系统面向的对象有学生或老师,以及书库管理人员。学生或老师向教材订购系统发送购书需求,收取领书单;教材订购系统向书库管理员返回缺书单,管理员向其发送进书通知。
2.业务需求
教材订购系统可以收取老师或学生的购书请求,通过查询数据库中指定书籍的数量,若数量足够,则向老师或学生发送领书单;若数量不足,则向书库管理员发送缺书单,提醒书库管理人员去采购,新书入库后,即发进书单通知给书库管理人员。
3.系统需求
系统能够身份识别,学生或老师以及书库管理员的登录进系统能够获得不同的系统权限,学生和老师只能提交购书请求,而书库管理员可以对书库里的缺少的图书进行补充。数据库需要有教材用书表、库存
表、缺书登记表、售书登记表、入库登记表、待购登记表等表用于存储系统用户所产生的数据。
2.数据流图
顶层数据流图
一层数据流图
二层数据流图
销售系统
订购系统
3.数据字典
库存表={书号+书名+数量+单价}
缺书登记表={登记日期+需求信息}
缺书信息=[学生信息|教师信息]+{书号+缺书数量+备注}
进书通知=进书日期+书号+书名+数量
购书单=单号+[学生信息|教师信息]+{书号+书名+购书数量+备注}
4.系统功能结构图
1.教材购销系统的最初上层框架设计
2.销售子系统初始SC图
3.采购子系统初始SC图
4.最终SC的上层框架
5.初售动作分支的最终SC图
5.流程图
业务流程图
系统数据流程图
四.思考题
(1)简述需求说明书,概要设计,详细设计说明书的主要内容。
软件需求说明书的编制是为了使用户和软件开发者双方对该软件的运行环境、功能和性能需求的初始规定有一个共同的理解,使之成为整个开发工作的基础;概要设计说明书编制的目的是说明对程序 系统的设计考虑,包括程序系统的基本处理流程、程序系统的组织结构、模块划分、功能分配、接口设计、运行设计、安全设计、数据结构设计和出错处理设计等,为程序的详细设计提供基础。;详细设计说明书编制目的是说明一个软件系统各个层次中的每一个程序 (每个模块或子程序)的设计考虑。
(2)结构化分析方法与面向对象分析方法有无本质上的不同?
结构化系统分析方法是采用“自顶向下,由外到内,逐层分解”的思想对复杂的系统进行分解化简,从而有效地控制了系统分析每一步的难度,并运用数据流图、加工说明和数据字典作为表达工具的一种系统分析技术;而面向对象的分析方法则是通过将数据和逻辑结构抽象成为对象,运用对象属性和方法等来操作和处理业务数据和逻辑的系统分析方法;两者的区别在于:当软件项目较小、系统分析员能力足够高的时候,结构化方法能快速的找到最简洁、高效率的逻辑模型,结构化方法对复杂问题的帮助有限,而面向对象的分析方法提供了一种方便的、可持续观测和扩展系统的机制,通过信息隐藏和封装等手段屏蔽了对象内部的执行细节,控制了错误的蔓延,对于需求变化频繁的系统,可以用面向对象软件系统的方法。
(3)对数据流图进行审查有何意义?
检查图中是否存在错误或不合理(不理想)的部分,确保两大特性一致性:分层DFD中不存在矛盾和冲突。完整性:是否有遗漏的数据流、加工等。
(4)给出一次完整的会议讨论纪要,包括议题,最终结果。