2020软件构造期末复习笔记第一、二章

题型

  • 填空:4个,8分
  • 简答、写代码、改代码:9个,合计56分
  • 设计题:3个,合计36分

简答与设计题: – 给出需求描述、ADT的基本代码 – 开展设计和代码:绘图/建模、设计、修改代码、写新 代码、写注释(AF/RI/Spec/Safety from Rep Exposure/Testing Strategy/Thread Safety Argument)、设计测试 用例、改进/优化各项质量指标等

一、二章考纲

  • 软件构造的多维度视图
  • 软件构造的阶段划分、各阶段的构造活动
  • 内部/外部的质量指标
  • 软件配置管理SCM与版本控制系统VCS
  • Git的结构、工作原理、基本指令
  • GitHub
    在这里插入图片描述
    本章核心在此图,红框内一定要记住
    在这里插入图片描述

软件构造的多维度视图

  • By phases: build- and run-time views
    按阶段划分:构造时/运行时视图
  • By dynamics: moment and period views
    按动态性划分:时刻/阶段视图
  • By levels: code and component views
    按构造对象的层次划分:代码/构件视图

软件构造过程其实就是不同视图之间的转换:三维度、八视图

本章最核心内容便是上图,下面分别介绍

Build Time View

含义:idea => requirement => design => code =>installable / executable package

  • Code-level view:代码的逻辑组织

functions, classes, methods, interfaces,

  • Component-level view:代码的物理组织

files, directories, packages, libraries,

  • Moment view:特定时刻的软件形态
  • Period view: 软件形态随时间的变化
(1)Build-time, moment, and code-level view
  • 词汇
    基于词汇的半结构化源代码(Lexical-based semi-structured source code)
  • 语法:
    面向语法的程序结构(Syntax-oriented program structure)
    例如AST,已经彻底结构化,java中存在专门的AST class将源代码变为一棵树,对树做各种操作==对源代码做修改。
  • 语义
    面向语义的程序结构(Semantics-oriented program structure),通常是图形化或形式化的,用于表达“需求”和“设计”思想,再转化成code
    例如:UML类图
(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
  • Source code 》files 》directories
  • file被封装到包内
  • 复用模块以libraries形式存在
    可利用Maven来管理配置文件,进而便捷地导入不同的库
    在这里插入图片描述
  • 将库集成到可执行程序中
    1.静态链接
    发生在Build Time库被拷贝进入代码形成整体,执行的时候无需提供库文件
    不依赖
    缺点:难以升级
    2.动态链接
    库不会加入可执行文件,只做标记
    运行时根据标记装载库至内存
    发布软件时,记得将程序所有依赖的动态库都复制给用户
    优点:易于升级
(4)Build-time, period, and component-level view

各项软件实体随时间会如何变化、SCI(配置项)、Version Control System (VCS)、Evolution Graph

Run Time View

  • Code Level:逻辑实体在内存中如何呈现?
  • Component Level:物理实体在物理硬件环境中如何呈现?
  • Moment view:逻辑/物理实体在内存/硬件环境中特定时刻的形态如何?
  • Period view:逻辑/物理实体在内存/硬件环境中的形态随时间如何变化?
(5) Run-time, moment, and code-level view

关注程序在运行时各个时刻的代码层面状态(内存等信息)

  • 代码快照图:描述程序运行时内存里变量层面的状态
  • Memory dump:当进程执行的过程中通过工具产生一个文件用来分析程序运行时的各个状态信息(eg:任务管理器
(6)Run-time, period and code-level view
  • UML中的时序图(不是类图)
  • Execution tracing 执行跟踪(堆栈执行跟踪)
(7)Run-time, moment, and component-level view
  • UML中的部署图
(8) Run-time, period, and component-level view
  • 事件日志:系统层面(前面的一个是code层面)

软件构造的阶段划分、各阶段的构造活动

直接上图:
在这里插入图片描述

内部/外部的质量指标

外部质量取决于内部质量,前者影响用户,后者影响开发者

  • 外部质量目标
    正确性、健壮性、可扩展性、复用性、兼容性(不同的软件系统之间相互可容易的集成)、性能(过早优化是万恶之源)、可移植性( 软件可方便的在不同的技术环境之间移植)、易用性、功能性、及时性等

  • 内部质量目标

    • 源代码相关因素(Source code related factors),如代码行数(LOC),循环复杂度等
    • 架构相关因素(Architecture-related factors),如耦合度聚合度等。
    • 可读性
    • 易理解性
    • 清晰度
    • 规模
  • 折中
    在这里插入图片描述
    最重要的有4个:正确性(最重要)、健壮性、可拓展性、可复用性

软件配置管理SCM与版本控制系统VCS

  • SCM:软件配置管理,用来追踪和控制软件的变化的任务。

  • SCI:软件配置项,软件中发生变化的基本单元(例如:文件)

  • SCM ≥ VCS

Git的结构、工作原理、基本指令

结构

  • .git directory本地CMDB(配置管理数据库)。
  • working directory(工作目录):本地文件系统。
  • Staging area(暂存区): 隔离工作目录和Git仓库。

原理

在.git目录中存放着下图(样子会不太一样,但内容一致)
在这里插入图片描述
Object Graph:版本之间的演化关系图,一条边A->B表征了“在版本B的基础上作出变化,形成了版本A”,图中给个节点就是一次Commit
在这里插入图片描述

Git object graph stores each version of an individual file once, and
allows multiple commits to share that one copy.

在这里插入图片描述
与传统VCS区别如上图

基本指令

在这里插入图片描述
添加文件:git add readme.txt
提交文件:git commit -m “message”
push到远程仓库:git push origin master
从远程仓库pull:git pull origin master(取回远程主机某个分支的更新,再与本地的指定分支合并,git pull = git fetch + git merge)

  • Git fetch:Git fetch会将数据拉取到本地仓库 - 它并不会自动合并或修改当前的工作。
  • git pull:git pull是从远程获取最新版本并merge到本地,会自动合并或修改当前的工作。

GitHub

省略

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值