软件构造中的多维视图可以分为以下几个维度
1.按照阶段划分 构建阶段和运行阶段 build-time 和run-time
2.按构造对象的层次划分 代码层面和组织层面 即 代码 / 构件视图code-level和component-level
3.按动态性划分:短时间和长时期层面 moment 和period
接下来我们对这几个阶段依次分析
一 Build-time views of a software system 开发阶段视图
属于构建阶段的视图
(1) Build-time, moment, and code level view 开发阶段、时刻、代码层面视图
词汇层面 语法层面 和语义层面
在词汇层面:
我们的词汇代码需要注意为半结构化的风格
在语法层面,我们使用抽象语法树AST 来进行语法分析
如图所示,在如下的语法树中,我们通过语法树完成了对while循环中 判断条件 主枝的分析,完成了对if从句条件分析和返回分析。通过语法树有利于了解。AST:彻底结构化,将源代码变为一棵树,对树做各种操作。对代码分析可以转为对语法树分析。
(2)Build-time, period, and code level view 开发阶段、周期、代码层面视图
这里我们关注code churn 代码变化。
在编码过程中我们可以记录代码的修改情况。可以通过版本工具来记录代码的修改情况。
通过借助该工具,我们可以较好地实现该版本作用,理解前后代码。
(3) Build-time, moment, and component-level view 开发阶段、时刻、模块化层面视图
代码的组织情况:可以进行模块化组织情况。库(Library)是一种代码组织。
编程时和 build 时,需要告诉编译器和 IDE 库的位置。链接分为动态和静态链接。
库分为: 操作系统提供的库
编程语言提供的库
第三方公司提供的库
自己积累的库
下图为在UML中代码实现形式:
(4) Build-time, period, and component-level view 开发阶段、周期、模块化层面视图
核心思想是版本 SCI配置项
工具有版本控制系统 Version Control System(VCS)
可以实现支持协同开发、帮助处于不同空间、不同组的多个人来进行开发与协同。
版本控制是给计算机软件不同状态分配唯一名字和编号的过程
二。 Run-time views of a software system 运行时视图
此为运行时视图的综述,主要是以运行视角看代码与组成。
1) Run-time, moment, and code level view 运行阶段、时刻、代码层面视图
代码快照图:描述程序运行时,内存里代码层面的状态。
使用MEMORY DUMP 内存信息转储来查看代码的状态也可以使用内存信息转储查看某个时间点或阶段内存的使用情况。如使用任务管理器宏观查看程序的内存使用情况。
2) Run-time, period, and code level view 运行阶段、周期、代码层面视图
用UML和日志方式记录程序执行中的调用次序,查看程序执行情况:方法、类的调用等。
3) Run-time, moment, and component-level view 运行阶段、时刻、模块化视图
Deployment diagram in UML
在运行阶段、时刻、模块化视图 以宏观方式查看该调用层次。
把各个模块的逻辑关系和调用层次表现出来了。
4) Run-time, period, and component-level view 运行阶段、周期、模块化视图
提供构建/系统层面来查看系统层面查看程序的使用情况。
三. 各个视图之间的转化
在软件构造中种类的转化如下
∅ → Code programming/coding
Code → Component design
Build time → Run time install deploy debug unit
Moment → Period Version Contol
三.软件系统的品质特性
外部质量因素
内部质量因素
保证内部质量因素的组成:
正确性 健壮性 可扩展性 可复用性 兼容性 设计的同构性 可移植性 易用性。
外部质量因素:
可读性 可理解性 清晰性 大小尺寸
1190600419 王子睿