[架构之路-92]:《软件架构设计:程序员向架构师转型必备》-2-解析软件架构的概念

news2024/9/20 20:52:16

前言:

什么是软件架构?不同的人,有不同的答案。因为架构无处不再,架构又有不同层面。

很多人都给架构定义,不同的人,对架构有不同的理解,很难统一。

本文是按照作者个人的理解,来展现一个程序员如何向架构师演进的路径。

第2章 解析软件架构概念

程序员要转向架构的第一道门槛就是:什么是架构?在众多定义中,如何立足自身的实际情况和起点,转型软件架构师?

2.1 软件架构概念分类

这个派别的思想源于建筑行业的架构,也源于架构这个单词本身,该派别人为,软件是一个系统,任何系统都是有组件、子系统、模块等组成的,通过分解还原一个软件系统,通过划分组件、子系统、模块来构建一个新的系统。

组成派是站在目标系统的角度,以目标系统为目标和中心。

决策派站在人的角度看目标系统,他们认为目标系统是人意愿的体现,是人的决策的体现,展现的是一种人对目标系统的一个愿景和规划。除了看得见的功能性需求,还包括了看不见的非功能性需求。

备注:站在程序员的角度,其实可以不用陷入到概念之争中,而是从实践出发,立足行为,先依葫芦画瓢,等进入高阶阶段后,再思考如何进行概念化和思想总结。

2.2 核心思想解析

2.2.1 关注软件系统的组成部分的分割与交互

任何系统,都是由各个子系统组成,子系统与子系统之间,子系统与外界一定存在一定的交互,没有交互的子系统是孤岛,注定没有存在的价值。组件本质是就是子系统。

2.2.2 架构是自顶向下逐步分层的树型决策

.......................................

2.2.3 架构无处不在

2.3 工程实践

2.3.1 基于手头上的实际代码理解架构

一方面,程序员能够跳出代码的细节,抽象出系统的架构。

另一方面,架构是不能脱离手头上的软件代码,重构架构,架构师的架构要落地,要有支撑点,在一个已有的系统上,架构是构建在代码之上的,是已有代码的抽象;在一个新系统中,代码是蓝图,是代码的蓝图,代码是按照架构的方式构建软件系统的。

一个好的系统,是架构师与程序员的通力合作和相互信任,程序员相信架构师的架构能力,架构师相信程序员的编程能力。

2.3.2 架构是类的抽象定义吗?

架构师如何只定义类的抽象定义,程序员只按照抽象定义去实现,就不需要架构师这个角色了,优秀的程序来充当就可以了。

架构师做能够程序员的基础上做增量工作:

  • 在更高层次上抽象系统,而不是类级别,如业务需求层面、用户层面和逻辑功能层面进行抽象,而类是实现层面的抽象。

  • 除了功能性需求,还要关注非功能性需求,确保架构的系统满足未来的需要,而不是仅仅当下的需要

  • 架构师要引领未来的方向,软件代码是满足业务需求的,软件架构要能够为当下的业务服务,同时也能适应未来的业务需求,只能需要有演进线路。

2.3.3 架构师不是需求工程师

架构师不仅仅要提软件的功能和非功能需要,还需要给出具体的技术方案,这是架构师与需求工程师最具备价值的地方。比如采用什么样的设计模式,技术方案选型等等。

2.4.4 不同派别不过是站的角度不同

感悟:

  • 架构的思想,不仅仅适合软件系统,也适合任何系统,包括国家、企业、公司、组织、团队。

  • 架构不仅仅是看得见的功能性需要,也包括看不见的非功能性需要,如稳定性、可靠性、安全性、伸缩性等。

  • 架构是不同层面上的抽象,是业务目标的一步一步实现过程:业务需求层=》用户层=》功能与非功能层=》代码设计=》代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/182704.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

React是不是MVVM架构吗?

首先说结论:不是 一、MVVM Model-View-ViewModel:一句话概括MVVM,操作数据,就是操作视图,就是操作DOM。开发者只需要完成包含申明绑定的视图模板,编写ViewModel中业务数据变更逻辑,View层则完…

Lua 协同程序(coroutine)

Lua 协同程序(coroutine) 参考文章: 菜鸟教程 https://zhuanlan.zhihu.com/p/480357405 https://zhuanlan.zhihu.com/p/76249973 Lua 协同程序(coroutine)与线程比较类似:拥有独立的堆栈,独立的局部变量,独立的指令指针&#xff0…

贪心算法(例题详细解说)

日升时奋斗,日落时自省 目录 1、选择排序 2、分割平衡字符串 3、买卖股票的最佳时机 II 4、跳跃游戏 5、钱币找零 6、多机调度问题 7、活动选择 8、无重复区间 贪心思想:顾名思义 贪 是该算法的一大特点,如何贪?&#x…

2023-01-28 clickhouse-聚合函数的源码再梳理

笔者在源码笔记1之中分析过ClickHouse的聚合函数的实现,但是对于各个接口函数的实际如何共同工作的源码,回头看并没有那么明晰,主要原因是没有结合Aggregator的类来一起分析聚合函数的是如果工作起来的。所以决定重新再完成一篇聚合函数的源码…

梦熊杯-十二月月赛-白银组题解-A.自由

A. Problem A.自由(freedom.cpp) 内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统 评测方式:文本比较 题目描述: 「蒙德」是「自由」的国度。 巴巴托斯认为,如果一个数的…

ch1_2 计算机的基本组成

计算机的基本组成 1. 冯 诺依曼计算机的特点 计算机由五大部件组成指令和数据 以同等地位 存于存储器, 可按地址寻访。指令和数据用二进制 表示指令由操作码 和 地址码 组成;存储程序;以运算器 为中心; 2. 硬件框图 存储器&am…

【Java集合】HashSet源码分析

目录 一、Set简介 二、HashSet简介 2.1 简介 2.2 HashSet继承关系 三、源码分析 3.1 成员属性 3.2 构造方法 3.3 添加元素 3.3.1 add()方法 3.3.2 addAll()方法 3.4 删除元素 3.4.1 remove()方法 3.4.2 removeAll()方法 3.5 查询元素 3.5.1 contains()方法 3.5.2 containsAll方…

项目管理:如何编写高质量的Makefile?

文章目录背景熟练掌握 Makefile 语法规划 Makefile 要实现的功能设计合理的 Makefile 结构掌握 Makefile 编写技巧技巧 1:善用通配符和自动变量技巧 2:善用函数技巧 3:依赖需要用到的工具技巧 4:把常用功能放在 /Makefile 中&…

nodeJS - 切换使用淘宝镜像【临时切换、 长期切换】

一、文章引导 #mermaid-svg-zWQadgqvTsLhAes4 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-zWQadgqvTsLhAes4 .error-icon{fill:#552222;}#mermaid-svg-zWQadgqvTsLhAes4 .error-text{fill:#552222;stroke:#55222…

自动驾驶感知——视觉感知经典算法

文章目录1. 车道线检测技术1.1 基于规则的车道线检测技术1.1.1 流程框架1.1.2 预处理模块1.1.3 车道线识别感兴趣区域提取1.1.4 灰度图转化1.1.5 灰度图去噪1.1.6 二值化操作1.1.7 鲁棒性参数估计——RANSAC1.1.8 后处理模块1.1.9 输出1.2 车道线检测技术发展路线2. 目标检测技…

10.图和树基础

一、基本介绍 1.图 图描述的是一些个体之间的关系。这些个体之间既不是前驱后继的顺序关系,也不是祖先后代的层次关系,而是错综复杂的网状关系。我们一般用图G(V,E)G(V,E)G(V,E)来表示,VVV表示结点,EEE表示边。 根据边是否有权值…

爱快软路由安装Docker插件

在爱快云 插件应用中开启Docker插件 在爱快web端页面的[系统设置]->[磁盘管理]->[磁盘分区]设置磁盘分区,选择普通存储,挂载路径名可以随便取。 点击[高级应用]->[插件管理] 点击页面的Docker图标。 启用Docker服务 点击中间的[镜像管理]&…

n皇后问题

n皇后问题 题目: 按照国际象棋的规则,皇后可以攻击与之处在同一行 或同一列 或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上,并且使皇后彼此之间不能相互攻击。 给你一个整数 n ,返回所有不同的…

基于java的大理旅游系统

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容:毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目介绍…

professional issue复习

Legal concepts Development of UK law • The Kingdom of England was established in 927. • The Principality of Wales was established in 1216. Common law • Following 1066, a unified system of law (English common law) slowly came into existence. It was “c…

漫谈cgroup

什么是cgroup cgroup 是linux内核的一个功能,用来限制、控制与分离一个进程组的资源(如CPU、内存、磁盘I/O等)。它是由 Google 的两位工程师进行开发的,自 2008 年 1 月正式发布的 Linux 内核 v2.6.24 开始提供此能力。 cgroup …

代码随想录算法训练营第30天 二叉树 java :39. 组合总和 40.组合总和II 131.分割回文串

文章目录LeetCode 39. 组合总和本题题解思路LeetCode 40.组合总和II本题题解思路LeetCode 131.分割回文串本题题解思路那么在代码里什么是切割线呢?那么在代码里什么是切割线呢?总结LeetCode 39. 组合总和 本题题解 思路 根据递归三部曲来分析 递归函…

单板硬件设计:存储器

在单板设计中,无论是涉及到一个简易的CPU、MCU小系统或者是复杂的单板设计,都离不开存储器设计: 1、存储器介绍 存储器的分类大致可以划分如下: ROM和RAM指的都是半导体存储器,ROM在系统停止供电的时候仍然可以保持…

visudo配置sudo权限

visudo配置sudo权限配置visudo仅允许字符终端登陆(tty)--授权localhost允许图形和tty登陆--授权all用户组提权-示例配置在sudoers.d目录下创建授权文件--推荐五段式配置三段式配置检查sudoers配置是否有误如何在sudo运行的命令中防止使用参数结果验证配置visudo https://blog.…

【数据结构】8.2 插入排序

文章目录前言1. 直接插入排序直接插入排序算法直接插入排序性能分析2. 折半插入排序3. 希尔排序希尔排序算法希尔排序算法分析排序方法比较前言 类似于俺们打牌时的插入,每抓来一张牌的时候,就将它放在合适的位置上,插入一张牌之后手里的牌仍…