西电软件体系结构核心考点汇总(期末真题+核心考点)
文章目录
- 前言
- 一、历年真题
- 二、核心考点汇总
- 2.1 什么是软件体系架构?(软件体系结构的定义)
- 2.2 架构风格优缺点
- 2.3 质量属性
- 2.4 质量评估
前言
主要针对西安电子科技大学《软件体系结构》的核心考点进行汇总。
【期末期间总结资料如下】
针对西电计科院软件工程专业大三《软件体系结构》期末考试复习资料。大部分知识点来自于老师的PPT,放心使用。
题型包括:简答题,选择题,大题
(如需要软件体系结构全部笔记资料,可以联系邮箱oax_knud@163.com
其他资料参考:西电计算机专业课资料汇总
一、历年真题
-
Utility Tree (16 points)
A software company plans to develop a data processing system. The development team analyzed the Quality Attributes, designed architecture and wanted to use Utility Tree to evaluate the architecture, followings are the scenarios.
a) There are two roles in the system: administrator and user. An administrator can create one or more users, and grant them the permissions accordingly.
b) Users are identified by their mobile phone numbers, and they can set a nickname having least 5 characters starting with letters.
c) The cost for adding a new data processing algorithm to the system by a developer is less than 10-person days.
d) The processing latency on main database need to be reduced to 100ms.
e) Change Web user interface in < 3-person weeks.
f) The application can display the processing results for an authentication user, and the authentication works 99.99% of the time.
g) When power outrage happens at site 1, it takes at most 3s to redirect
all traffic from site 1 to site 3.
h) If a user forgets his password, he can reset his password by receiving a message from the system.
i) The latency for processing a 1GB video data (1080p) must be less than 10s.
j) The network failure can be detected automatically and recovered in < 2.5 min.
k) The system must have a user authorization database to record the user permissions, and the authorization works 99.99% of the time.
According the scenarios, please construct a Utility Tree. -
Architecture Evaluation (20 points)
Identifying and recording risks and non-risks, sensitivity points and tradeoffs are important tasks in architecture evaluation. Please describe the definitions of risk, non-risk, sensitivity point and tradeoffs and then read the following descriptions and point out each description is a risk, non-risk, sensitivity point or tradeoff.
a) The number of concurrent requests will affect the number of transactions a database can process per second.
b) Changing the level of authentication could have a significant impact on both security and performance.
c) Some business processing component is provided by a third-party
company, there is no way of detecting the failure of them directly.
d) Assuming the request arrival rate is twice per second, and the average processing time is less than 80ms; a 1 second response time seems reasonable for our system.
e) Some of the legacy data processing components are implemented by the C++ programming language, which should be encapsulated ( 封装 ) first and are hard for a Java program to maintain and modify them.
f) The selection of the encryption algorithm might be closely related to the number of bits of encryption
二、核心考点汇总
2.1 什么是软件体系架构?(软件体系结构的定义)
基于1993年D Garlan,Mshaw 的软件体系结构定义,可以认为软件体系结构由三大要素组成,分别为:组件,连接件,约束。其作用如下:
- 组件:具有某种功能的可重用的软件模块单元,表示了系统中主要的计算单元和数据存储。
- 连接件:表示了组件之间的交互。简单的连接件有:管道,过程调用、事件广播等。复杂的连接件有:客户-服务器通信协议,数据库和应用之间SQL连接等。
- 约束:表示了组件和连接件的拓扑逻辑和约束。
2.2 架构风格优缺点
掌握所有架构风格优缺点和原理。
以数据流风格为例:
1、 总体描述:
【组件】数据流风格组件为计算模型,包括输入接口和输出接口,输入接口读取数据流的数
据,通过计算模型处理数据得到结构,将其写入输出接口。【连接件】连接件为数据流,前
一个组件的输出接口输出的数据通过数据流传输到下一个组件的输入接口,连接件主要起传
输数据的作用。
2、 批处理风格【大量整体数据传输时适用】
【组件】批处理风格的组件是独立计算的程序,【连接件】连接件为某种传输数据的媒介
【优点】
- 无需考虑同步问题:数据是完整的,以整体的方式在组件之间进行传输,因此无需考虑
同步数据问题; - 可以随机存取数据:由于数据是完整传输的,因此在获取数据时,可以完整的存取所有
数据。
【缺点】
- 计算效率低,系统性能差,无法并行计算:批处理的处理单元必须在前一个处理单元完
全处理完毕后再进行计算,因此系统计算效率低。 - 无法实时计算:每个组件之间的计算顺序是固定的,因此若实时计算,会存在计算延时
现象 - 交互性差:每个组件都对完整的数据进行计算,因此在处理数据过程中,用户不易交互。
【应用】编译器,CASE 应用程序;基于 eclipse 的代码重复检测工具
3、 管道过滤器【流式数据传输并且知道流向时适用】
【组件】管道过滤器风格的组件是过滤器,过滤器将源数据转换为目标数据,功能包括增加,
删除,转换,合并,分解。【连接件】管道过滤器风格的连接件是管道,管道的主要作用在
于在过滤器之间传输数据。两个过滤器之间通过管道进行数据的传输。
【优点】
- 可以并行计算:由于管道过滤器输入数据为流式数据,因此对于不同的数据流可以在不
同的过滤器上进行并行计算。 - 支持软件的复用:过滤器之间只要数据格式满足输入输出要求,任何两个过滤器均可以
进行连接。 - 组件具有良好的隐蔽性,高内聚,低耦合的特点:整个系统的输入输出可以看作内部多
个过滤器行为的合成。 - 系统易于维护和扩展:系统中仅需要通过增加过滤器便可以进行系统功能的扩展;同时
也仅需要维护某一个过滤器便可以进行功能的维护。
【缺点】
- 性能不高:过滤器之间数据的输入输出格式往往没有统一的标准,因此在过滤器之间数
据进行传输的过程中,过滤器要对数据进行解析才能继续使用数据,系统大量事件用户
数据格式的转换与解析,因此实际功能的效率较低。 - 不适合用户交互处理:当系统需要增量改变时,管道过滤器往往无法进行很好的工作。
【应用】编译器,图像处理程序,语音处理,数据处
2.3 质量属性
了解定义,六要素,以及对应的策略
以可用性为例进行说明:
可用性 availability
1、 定义:在要求的外部资源得到保证的前提下,产品在规定条件下和规定时刻或时间区间
内处于可执行规定功能状态的能力。
2、 六要素
策略:
2.4 质量评估
背会风险,非风险,敏感点,权衡点定义,并会根据场景分析哪个是风险,非风险,敏感点,权衡点。
相关文章:

西电软件体系结构核心考点汇总(期末真题+核心考点)
文章目录前言一、历年真题二、核心考点汇总2.1 什么是软件体系架构?(软件体系结构的定义)2.2 架构风格优缺点2.3 质量属性2.4 质量评估前言 主要针对西安电子科技大学《软件体系结构》的核心考点进行汇总。 【期末期间总结资料如下】 针对西电计科院软件工程专业大三《软件体…...

SRS源码分析-SDP内容解析
前言 在学习SRS的RTC模块之前,首先来分析下SRS在将rtmp推流转成rtc流,通过浏览器拉取webrtc流场景下产生的SDP内容 SDP格式介绍 SDP数据是文本格式,由多个 <key><value> 表达式构成,<key>的值只能是一个字符…...

HTML 颜色
HTML 颜色 HTML 颜色采用的是 RGB 颜色,是通过对红 (R)、绿 (G)、蓝 (B) 三个颜色通道的变化以及它们相互之间的叠加来得到各式各样的颜色的,RGB 即是代表红、绿、蓝三个通道的颜色。 Color Values HTML 颜色由一个十六进制符号来定义,这个符…...

MySQL高可用架构之InnoDB Cluster部署
MySQL高可用架构之InnoDB Cluster部署InnoDB Cluster适用场景准备工作安装MySQL Shell使用MySQL Shell搭建InnoDB Cluster初始化第一个实例创建InnoDB Cluster添加副本实例创建相关用户MySQL Router部署安装MySQL Router引导MySQL Router启动MySQL Router环境准备 主机名IPOS版…...

Linux安装minio单机版
说明:因为前面记录了一下minio的使用,这里说一下minio的安装,只是单机版哦 环境准备:Linux系统 说明图: 1.创建文件夹命令 我的是安装在/usr/local 文件夹下面的创建文件夹命令 #进入目标文件夹 cd /usr/local#创建…...

网络总结知识点(网络工程师必备)四
♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维课堂笔记,努力不一定有收获,但一定会有收获加油!一起努力,共赴美好人生! ♥️夕阳下,是最美的绽放,树高千尺,落叶归根人生不易,人间真情 目录 前言 71.NAPT有什么特点? 72.ARP欺骗解决方法...

数据结构——第三章 栈与队列(5)
共用栈和双队列1.共用栈2.双端队列栈与队列的本章小节1.共用栈 在实际应用中,有时一个应用程序需要多个栈,但这些栈的数据元素类型相同。假设每个栈都采用顺序栈,由于每个栈的使用情况不尽相同,势必会造成存储空间的浪费。若让多…...

CSDN竞赛第33期题解
CSDN竞赛第33期题解 1、题目名称:奇偶排序 给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。(奇数和偶数的顺序根据输入的数字顺序排 列) #include<bits/stdc.h> using namespace std; t…...

农产品销售系统的设计与实现
技术:Java、JSP等摘要:这篇文章主要描述的是农产品蔬菜在线销售系统的设计与实现。主要应用关于JSP网站开发技术,并联系到网站所处理的数据的结构特点和所学到的知识,应用的主要是Mysql数据库系统。系统实现了网站的基本功能&…...

C语言-基础了解-08-C判断
C判断 一、C判断 判断结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的)。 C 语言把任何非零和非空的值假定为 true,把零或 null 假…...

用数组名作函数参数的详解,以及形参实参采用数组名,形参实参采用指针变量的几种情况解析
关于地址,指针,指针变量可以参考我的这篇文章: 地址,指针,指针变量是什么?他们的区别?符号(*)在不同位置的解释?_juechen333的博客-CSDN博客https://blog.csd…...

k8s中的PV和PVS
前言:容器磁盘上的文件的生命周期是短暂的,这就使得在容器中运行重要应用时会出现一些问题。首先,当容器崩溃时,kubelet 会重启它,但是容器中的文件将丢失——容器以干净的状态(镜像最初的状态)…...

【云原生】Gateway网关选型
网关一般分为流量网关和业务网关,流量网关负责接入所有的流量,并分发给不同的子系统,那在具体的业务接入之前,还有一层业务网关。流量网关提供全局性的、与后端业务应用无关的策略,例如 HTTPS证书卸载、Web防火墙、全局…...

QML Button详解
1.Button简介 Button表示用户可以按下或单击的按钮控件。按钮通常用于执行一个动作,或回答一个问题。典型的按钮有确定、应用、取消、关闭、是、否和帮助。 Button继承自AbstractButton,提供了以下几种信号。 void canceled() //当按…...

【编程实践】什么是好/坏代码?非程序员的示例
What is good/bad code? An illustrated example for non-programmers 什么是好/坏代码?非程序员的示例 目录 What is good/bad code? An illustrated example for non-programmers什么是好/坏代码?非程序员的示例 So what is ‘Bad Code’, as a layperson?那么,作为…...

一个简单的Sublime设置
问题 如果读者熟悉我,应该会发现我经常使用 VSCode 作为主力编辑器,但随着我安装的 VSCode 的插件逐渐增加,我发现对于部分较小的任务使用 VSCode 过于笨重,比如简单的 Markdown 文件编辑工作。 在经过一系列寻找后,…...

c语言经典例题-选择结构程序设计进阶
(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 快递费用计算: 题目: 代码思路: 代码表示: 计算一元二…...

NOI 2023春季测试 游记
怎么说,没遇到大波折即幸运。 Day 0 睡到下午三点,然后列了一堆复习计划,大概是左偏树等一些早就忘没的科技。 但是沉迷打块,最后基本什么计划也没完成。 白天睡多了,晚上睡不着,大概半梦半醒过了一整夜…...

【VC 7/8】vCenter Server 基于文件的备份和还原Ⅱ——使用 FTP 协议备份 VC(VAMI 英文)
目录2. 备份 vCenter Server2.1 使用 FTP 协议备份 VC(1)登录 vCenter Server 管理界面(2)进入Backup页面(3)配置 Backup Schedule(4)开始备份(5)备份成功&am…...

Python基础—文件操作(二)
Python基础—文件操作(二) CSV格式文件 逗号分隔值,以纯文本形式存储表格数据 由任意数目的记录组成,记录间以换行符分隔 每条记录由字段组成,字段间用逗号或制表符分隔 每条记录都有同样的字段序列 如有列名,位于文件第一行 每条…...

学校的班级个数【并查集基础应用,Java实现】
题目描述 现有一个学校,学校中有若干个班级,每个班级中有若干个学生,每个学生只会存在于一个班级中。如果学生A和学生B处于一个班级,学生B和学生C处于一个班级,那么我们称学生A和学生C也处于一个班级。 现已知学校中共…...

WSL2使用Nvidia-Docker实现CUDA版本自由切换
众所周知,深度学习的环境往往非常麻烦,经常不同的项目所依赖的 torch、tensorflow 包对 CUDA 的版本也有不同的要求,Linux 下进行 CUDA 的管理比较麻烦,是一个比较头疼的问题。 随着 WSL2 对物理机显卡的支持,Nvidia-…...

pygame9 扫雷游戏2
一、响应鼠标左键事件 pygame.MOUSEBUTTONDOWN 表示鼠标事件发生, pygame.mouse.get_pressed()[0] 确认是鼠标左键被按下 pygame.mouse.get_pos() 获取到鼠标按下时的坐标值。 因此,我们可以在事件逻辑中例用此三个函数判断鼠标事件及对应的坐标&#x…...

逻辑电路代数运算(上)
逻辑代数L是一个封闭的代数系统,由一个逻辑变量集K,常量0和1,以及与或非三种基本运算构成。 参与逻辑运算的变量叫逻辑变量,用字母A,B……表示。每个变量的取值非0 即1。 0、1不表示数的大小,而是代表两种不…...

Rabbit快速入门
入门案例 需求:使用简单模式完成消息传递 步骤: 创建工程(生成者、消费者) 分别添加依赖 编写生产者发送消息 编写消费者接收消息 3.1.2. 添加依赖 往heima-rabbitmq的pom.xml文件中添加如下依赖: <dependenc…...

【react+ts- forwardRef】
reactts- forwardRef1. 学习资料2. 普通input透传2.1 TS版本2.2 JS版本3. TS-Antd-Form组价透传引用传递(Ref forwading)是一种通过组件向子组件自动传递 引用ref 的技术。对于应用者的大多数组件来说没什么作用。但是对于有些重复使用的组件,…...

计算机网络-- 网络层(day06)
文章目录网络层思维导图IPv4地址的应用规划定长的子网掩码变长的子网掩码VLSMIP数据报的发送和转发过程主机发送IP数据报路由器转发IP数据报静态路由选择动态路由选择路由选择协议概述常见的路由选择协议路由器的基本结构路由信息协议RIP的基本工作原理开放最短路径优先OSPF的基…...

docker 镜像
一、介绍 镜像:是一种轻量级、可执行的独立软件包,它包含运行某个软件所需的所有内容,我们把应用程序和配置依赖打包好形成一个可交付的运行环境(包括代码,运行时需要的库,环境变量和配置文件等)这个打包好的运行环境就是image镜像文件。 只有通过这个镜…...

JUC并发编程与源码分析笔记11-Java对象内存布局和对象头
先从阿里及其它大厂面试题说起 你觉得目前面试,你还有那些方面理解的比较好,我没问到的,我说了juc和jvm以及同步锁机制那先说juc吧,说下aqs的大致流程cas自旋锁,是获取不到锁就一直自旋吗?cas和synchronized区别在哪…...

JavaSE之集合篇
文章目录前言一、集合概述集合继承结构图二、Collection接口中常用方法2.1Collection中存放什么元素?2.2常用方法2.3迭代器三、List接口中常用的方法四、ArrayList初始化容量及扩容五、Vector六、Map接口常用方法七、Properties前言 由于在刷题过程中,经…...