2.4 数据流图(DFD)
3.2 实体-联系(E-R)图
数据模型包含三种相互关联的信息:数据对象、描述数据对象属性及数据对象彼此间相互连接的关系。
软件:PowerDesigner
3.3 规格说明方式
每个模块完成一个子功能,把这些模块集成起来构成一个整体,可以完成指定的功能满足用户的需求。
模块化优点:结构清晰,容易阅读和理解,容易测试和调试,有助于提高软件的可靠性,可修改性,便于组织和管理。
抽象——求精
信息隐藏和局部化
一个模块内包含的信息(过程和数据)对于不需要这些信息的模块来说,是不能访问的。
模块独立:度量标准内聚和耦合
耦合:对一个软件结构内不同模块之间互连程度的度量。耦合强弱取决于模块间接口的复杂程度,进入或访问一个模块的点,以及通过接口的数据。应尽可能松散耦合。
内聚:标志一个模块内各个元素彼此结合的紧密程度,它是信息隐蔽和局部化概念的自然扩展。应尽可能高内聚。
4.2 启发规则
改进软件结构提高模块独立性
模块规模应该适中
深度、宽度、扇出和扇入都应适当
模块的作用域应该在控制域之内
力争降低模块接口的复杂程度
设计单入口单出口的模块
模块功能应该可以预测
描述软件结构方法:层次图
·(变换流和事务流)
面向数据流方法的设计过程:
盒图(N-S图)
面向对象的分析设计实例:银行ATM业务分析设计
面向对象分析,就是抽取和整理用户需求并建立问题域精确模型的过程。在概念上面向对象分析大体上按照下列顺序进行:寻找类与对象,识别结构,识别主题,定义属性,建立动态模型,建立功能模型,定义服务。分析不可能严格地按照预定顺序进行,大型、复杂系统的模型需要反复构造多遍才能建成。通常,先构造出模型的子集,然后再逐渐扩充,直到完全、充分地理解了整个问题,才能最终把模型建立起来。
实例:银行ATM业务分析设计
需求陈述:
某银行拟开发一个自动取款机系统,它是一个由自动取款机、中央计算机、分行计算机及柜员终端组成的 络系统。
ATM和中央计算机由总行投资购买。总行拥有多台ATM,分别设在全市各主要街道上。分行负责提供分行计算机和柜员终端。柜员终端设在分行营业厅及分行下属的各个储蓄所内。该系统的软件开发成本由各个分行分摊。
银行柜员使用柜员终端处理储户提交的储蓄事务。储户可以用现金或支票向自己拥有的某个账户内存款或开新账户。储户也可以从自己的账户中取款。一个储户可能拥有多个账户。柜员负责把储户提交的存款或取款事务输进柜员终端,接收储户交来的现金或支票,或付给储户现金。
柜员终端与相应的分行计算机通信,分行计算机具体处理某个账户的事务并且维护账户。
拥有银行账户的储户有权申请领取现金兑换卡。使用现金兑换卡可以通过ATM访问自己的账户。目前仅限于用现金兑换卡在ATM上提取现金(即取款),或查询有关自己账户的信息(例如,某个指定账户上的余额)。将来可能还要求使用ATM办理转账、存款等事务。
所谓现金兑换卡就是一张特制的磁卡,上面有分行代码和卡 。分行代码唯一标识总行下属的一个分行,卡 确定了这张卡可以访问哪些账户。通常,一张卡可以访问储户的若干个账户,但是不一定能访问这个储户的全部账户。每张现金兑换卡仅属于一个储户所有,但是,同一张卡可能有多个副本,因此,必须考虑同时在若干台ATM上使用同样的现金兑换卡的可能性。也就是说,系统应该能够处理并发的访问。
当用户把现金兑换卡插入ATM之后,ATM就与用户交互,以获取有关这次事务的信息,并与中央计算机交换关于事务的信息。首先,ATM要求用户输入密码,接下来ATM把从这张卡上读到的信息以及用户输入的密码传给中央计算机,请求中央计算机核对这些信息并处理这次事务。中央计算机根据卡上的分行代码确定这次事务与分行的对应关系,并且委托相应的分行计算机验证用户密码。如果用户输入的密码是正确的,ATM就要求用户选择事务类型(取款、查询等)。当用户选择取款时,ATM请求用户输入取款额。最后,ATM从现金出口吐出现金,并且打印出账单交给用户。
建立对象模型:
确定需求中的类与对象和操作,并筛选掉不正确和不必要的。
方法:将需求陈述中的名词作为候选对象,动词作为候选服务(操作),并提取需求陈述中隐含的类。之后筛除掉冗余、无关、笼统、属性、操作、实现等不正确和不必要的类。
-
初步筛选,剩下下列类:ATM、中央计算机、分行计算机、柜员终端、总行、分行、柜员、储户、账户、事务和现金兑换卡。
-
类确定后,确定类之间的关联。经初步分析得出的关联只能作为候选的关联需经过进一步筛选,以去掉不正确的或不必要的关联:已删去的类之间的关联、与问题无关的或应在实现阶段考虑的关联、瞬时事件、依赖关系、三元关联、派生关联。
-
确定属性
应该仅考虑与具体应用直接相关的属性,不要考虑那些超出所要解决的问题范围的属性。
在分析过程中应该首先找出最重要的属性,以后再逐渐把其余属性增添进去。认真考察经初步分析而确定下来的那些属性,从中删掉不正确的或不必要的属性:误把对象当作属性、把链属性误作为属性、把限定误当成属性、误把内部状态当成了属性、过于细化、存在不一致的属性。
最终ATM对象模型
相关资源:陈式太极拳教学软件+注册机1-专业指导文档类资源-CSDN文库
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!