(1)为在需求分析阶段所确定的数据对象选择逻辑表示,需要对不同结构进行算法分析,以便选择一个最有效的设计方案。
(2) 确定对逻辑数据结构所必需的那些操作的程序模块(软件包),以便限制或确定各个数据设计决策的影响范围。
无论采取什么样的设计方法,如果数据设计得好,往往能产生很好的软件系统结构,具有很强的模块独立性和较低的程序复杂性。
Pressman提出了一组原则,用来定义和设计数据。
(1)用于软件的系统化方法也适用于数据。应当考虑几种不同的数据组织方案,还应当分析数据设计给软件设计带来的影响。
(2)要确定所有的数据结构和在每种数据结构上施加的操作。对于涉及到软件中若干个功能的实现处理的复杂数据结构,可以为它定义一个抽象数据类型。
(3)应当建立一个数据词典并用它来定义数据和软件的设计。
(4)低层数据设计的决策应推迟到设计过程的后期进行。可以将逐步细化的方法用于数据设计。在需求分析时确定总体数据组织,在概要设计阶段加以细化,而在详细设计阶段才规定具体的细节。
(5)数据结构的表示只限于那些必须直接使用该数据结构内数据的模块才能知道。此原则就是信息隐蔽和与此相关的耦合性原则,把数据对象的逻辑形式与物理形式分开。
(6)数据结构应当设计成为可复用的。建立一个存有各种可复用的数据结构模型的构件库,以减少数据定义和设计的工作量。
(7)软件设计和程序设计语言应当支持抽象数据类型的定义和实现。如果没有直接定义某种复杂数据结构的手段,这种结构的设计和实现往往是很困难的。
以上原则可适用于软件工程的定义阶段和开发阶段。“清晰的信息定义是软件开发成功的关键”。