Build-time:软件的构造阶段。
Code-level:代码的逻辑组织。源代码如何被方法、函数、类和接口等底层模块组织起来,以及其中代码之间的依赖关系。
Component-level:代码的物理组织。代码块之间的关系,如文件、包等。
Moment view:特定时刻的软件形态。
Period view:软件形态随时间的变化。
(1) Build-time, moment, and code-level view
词汇层面:Lexical-oriented source code
半结构化:近乎自然语言的 风格+遵循特定的编程语法
语法层面:Syntax-oriented program structure: e.g., Abstract Syntax Tree (AST)
AST:彻底结构化,将 源代码变为一棵树, 对树做各种操作=对源代码的修改
语义层面:Semantics-oriented program structure: e.g., Class Diagram
语义:源代码具体 想实现什么目标? 源代码—>现实世界
用于表达“需求” 和“设计”思想, 再转化成code
通常是图形化或形式化的
(2) Build-time, period, and code-level view
Code churn 代码变化: Lines added, modified or deleted to a file from one version to another
(3) Build-time, moment, and component-level view
关注库(这里指静态链接库)和包,库有这几种来源:操作系统提供的库、编程语言提供的库、第三方公司提供的库以及自己积累的库。
开发者像使用编程语言指令一样使用库中的功能
操作系统提供的库
编程语言提供的库第三方公司提供的库
你自己积累的库
(4) Build-time, period, and component-level view
各项软件实体随时间如何变化
Version Control System (VCS)
(5) Run-time, moment, and code-level view
代码快照图:描述程序运行时内存 里变量层面的状态
(6) Run-time, period and code-level view
用日志方式记录程序执行的调用次序
(7) Run-time, moment, and component-level view
Deployment diagram in UML
(8) Run-time, period, and component-level view
事件日志:系统层面