软件体系结构形式化方法
时间:2024-01-21 22:35:01 | 来源:信息时代
时间:2024-01-21 22:35:01 来源:信息时代
软件体系结构形式化方法是指在严格的数学基础(逻辑、代数、自动机、图论等)之上建立的软件开发方法,它是数学上的综合、分析技术的应用,用于开发计算机控制的系统。它可提供一个用于模型设计和分析的严格而有效的途径。其主要目的是克服自然语言、图表等非形式化方法描述体系结构存在的不足。由于形式化方法能在早起发现系统中的不一致、歧义、不完全和错误,目前己被证明是一种行之有效的减少设计错误的方法,是提高软件系统可信度的重要途径。开始的时候,研究人员运用形式化方法描述单个软件系统的体系结构或者体系结构风格。然后,逐步提出运用形式化方法描述和分析体系结构的通用模型。根据对目标软件系统进行说明的方式,形式化方法可以分为如下两种:
1、面向模型的方法。在面向模型的方法中,对目标软件系统的说明是为其构造一个模型,该模型的构成成分是一些具有特性的数据抽象,如域、元组、集合、序列、包、映射等。
2、面向性质的方法。这种方法通过直接给出目标软件系统的一组特性来描述目标软件系统,通常是一组目标软件系统必须满足的形式公理。在面向性质的方法中,其形式规格说明仅描述目标软件系统的性质,而不涉及实现方法。
根据表达能力,形式化方法大致可分为五类:
1、基于模型的方法。给出系统(程序)状态和状态变换与操作的显式但亦是抽象的定义,但对于并发没有显式的表示,如基于模型的形式规约语言Z和VDM。
2、代数方法。通过联系不同操作间的行为关系而给出操作的隐式定义,而不定义状态,同样它亦未给出并发的显式的表示,如基于性质的代数规约语言OBJ, LARCH, CLEAR。
3、过程代数方法。给出并发过程的一个显式模型,并通过过程间允许的可观察的通讯上的限制(约束)来表示行为,如CSP, CCP。
4、基于逻辑的方法。有很多方法采用逻辑来描述系统的特性,包括程序允许的低级规范和系统时间行为的规范,如时态逻辑。
5、基于网络的方法。根据网络中数据流显式地给出系统的并发模型,包括数据在网中从一个结点流向另一个结点的条件。如Petri网、谓词变换网。
形式化方法的研究和应用己有30多年的历史。最初的产生是由Dikstra和Hoare在程序难验证方面的工作中和Scott,Strachey以及其他学者在程序语义方面的工作基础上发展起来的。
在软件开发过程中,用户需求的规格说明(体系结构描述)非常重要,其使用者包括用户、系统分析员、设计与编程人员、测试人员和验收人员。规格说明对这些人员来说是一个可靠的参照点;系统分析员接受用户的需求,产生目标软件系统的规格说明;设计与编程人员根据规格说明,进行模块设计并产生最终程序代码;测试人员和验收人员验证最终程序代码是否满足规格说明。
-
网站
-
营销
-
设计
-
运营
-
优化
-
效率
-
专注
-
电商
-
方案
-
推广
微信公众号
版权所有© 亿企邦 1997-2025 保留一切法律许可权利。