软件架构设计(一):软件架构概念

  不积跬步,无以至千里。
  程序员在向架构师转型时,都希望尽早清除“什么是架构”。但是架构的额定义又多又乱。已造成“什么是架构”成了程序员向架构师转型的最大门槛。

1.1 软件架构的分类

  一个词(比如电脑),可能并不代表一件单独的东西,而是代表了一类事物。这个一般性的表述就是我们通常所说的概念。
  也许大家期待一个干净利落的软件架构概念,但这有点儿难。对此,马丁·福勒给出的评价是:

软件业的恶人乐于做这样的事——找一些词汇,并将它们引申到大量微妙而又相互矛盾的含义中。一个最大的受害者就是架构这个词。很多人都试图给架构下定义,而这些定义本身却很难统一。

   本专栏将软件架构概念分为两大流派——组成派和决策派,帮助各级开发人员快速理清“什么是架构的”的基础问题。下面就采用这种方式介绍结构概念。

2.1.1 组成派

  Mary Shaw在《软件体系结构:一门初露端倪学科的展望》中,为软件架构给出了非常简明的定义:

软件系统的架构将系统描述为计算机组件与组件之间的交互。

  必须说明,上述定义的组件是广泛意义上的元素之意,并不是指和CORBA、DCOM、EJB等相关的专有的组件概念。计算组件页式泛指,其实计算组件可以进一步细分为处理组件、数据组件、连接组件等。总之,组件可以指子系统、框架、模块、类等不同粒度的软件单元,他们可以担负不同的计算职责。
  上述定义是组成派软件架构的典型代表,有如下两个显著特点:

  1. 关注架构实践中的客体——软件,以软件本身为描述对象。

  2. 分析了软件的组成,即软件由承担不同计算任务的组件组成,这些组件通过相互交互完成更高层次的计算。

2.1.2 决策派

  RUP(Rational Unified Process,统一软件开发过程)给出的架构的定义非常冗长,但其核心思想非常明确:软件架构是在一些重要方面所作出的决策集合。下面看看它的定义:

软件架构包含了关于以下问题的重要决策:

  • 软件系统的组织;

  • 选择组成系统的结构元素和他们之间的接口,以及当这些元素相互协作时所体现的行为;

  • 如何组成这些元素,使他们逐渐合成为更大的子系统;

  • 用于指导这个系统组织的架构风格:这些元素以及它们的接口、协作和组合。

  • 软件架构并部基金注重软件本身的结构和行为,还注重其他特性:使用、功能性、性能、弹性、重用、可理解性、经济和技术的限制及权衡,以及美学等。

该定义是“决策派”软件架构概念的典型代表,有如下两个显著的特点:

  • 关注架构实践中的主体——人,以人的决策为描述对象。

  • 归纳了架构决策的类型,指出架构决策不仅包括关于软件系统的组织、元素、子系统和架构风格等几类决策,还包括众多非功能需求的决策。

2.1.2 软件架构概念大观

  下面再列举几个著名的软件架构定义,请大家:

  • 结合实践,体会自己所认为的“架构”是什么,也可以问问周围同事对架构的理解;

  • 体会到专家们对“架构”下的定义虽然多,但万变不离其宗——都是围绕“组成”和“决策”两个角度定义架构的;

  • 注意区分,下面的定义1和定义2属于架构概念的“决策派”,而定义3、4、5、6、7属于架构概念的“组成派”;

  • 关注定义7,它将架构的多视图“本性”体现到了定义当中,是相对比较新的定义,业界都深表认同。

1.Booch、Rumbaugh 和 Jacobson的定义

  架构师一系列重要决策的集合,这些决策与以下内容有关:软件的组织,构成系统的结构元素及其接口的选择,这些元素在像话协作照片那个明确表现出的行为,这些结构元素和行为元素进一步组合所构成的更大规模的系统,以及指导这一组织——包括这些元素及其接口、它们的协作和它们的组合——架构风格。

2.2 概念思想的解析

2.2.1 软件架构关注分割和交互

  架构设计师分与合的艺术。
  “软件系统的架构将系统描述为计算机组件及组件之间的交互”,shaw的这个定义从“软件组成”角度解析了软件架构的要素:组件及组件之间的交互。架构=组件 交互,组件和111组件之间有交互关系(图中的交互“关系”建模成UML关联类)。
下面以大家熟悉的MVC架构为例进行说明。如图2-1所示。

  • 采用MVC架构的软件包含了这样的3种组件:Model、View、Controller.

  • 这三种组件通过交互来协作:View创建Controller后,Controller根据用户交互调用Model的对应服务,而Model会将自身的改变通知View,View则会读取Model的信息以更新自身。

来源:https://www.icode9.com/content-4-785801.html

(0)

相关推荐

  • 软件架构、框架、模式、模块、组件、插件、中间件一文打尽

    一.架构 软件架构(software architecture)是一系列相关的抽象模式,用于指导大型软件系统各个方面的设计.软件架构是一个系统的草图.软件体系结构是构建计算机软件实践的基础.也称为软件 ...

  • 基于SIMULINK开发面向服务的汽车应用架构(SOA)。

    汽车功能越来越多地由软件定义,使它们更容易被黑客攻击.汽车电气工程向面向服务的架构演变,无论是向ADAS或信息娱乐系统添加新功能,还是修补漏洞,OTA更新都是一个有价值的解决方案.面向服务的架构(SO ...

  • UC头条:软件架构设计

    一.软件架构设计 软件或计算机系统的软件架构是该系统的一个(或多个)结构,而结构由软件元素.元素的外部可见属性及它们之间的关系组成. 软件系统架构是关于软件系统的结构.行为和属性的高级抽象.指定了软件 ...

  • 《车载SOA软件架构技术规范1.0》解读3:车载SOA软件服务设计规范

    《车载SOA软件架构技术规范1.0》解读3:车载SOA软件服务设计规范

  • 软件架构评估指导书

    软件架构评估指导书

  • 《车载SOA软件架构技术规范1.0》解读1:SOA架构技术概述及技术规范现状

    背景: <车载SOA软件架构技术规范1.0>是由AUTOSEMO撰写的首个车载SOA软件架构技术规范,这是首个面向汽车行业SOA软件架构的理论体系.近期,AUTOSEMO将组织针对本规范的 ...

  • 系统架构设计师

    像学写文章一样,在学会字.词.句之后,就应上升到段落,就应追求文章的"布局谋篇",这就是架构.通俗地讲,软件架构设计就是软件系统的"布局谋篇". 人们在软件工程 ...

  • 嵌入式软件架构设计分层思路

    在正规的项目开发中,项目往往是并行开发的,也就是说硬件设计.底层软件设计.应用软件设计等是同步进行的.比如说在开发板上调试模块驱动,在其他平台上调试应用程序再移植到目前这个平台等. 嵌入式专栏 1 为 ...

  • 干货 | 嵌入式系统软件架构设计

    整理 :嵌入式云IOT技术圈,作者:veryarm 1. 前言 嵌入式是软件设计领域的一个分支,它自身的诸多特点决定了系统架构师的选择,同时它的一些问题又具有相当的通用性,可以推广到其他的领域. 提起 ...

  • 嵌入式软件架构设计之分层设计

    在实际的项目开发中,项目往往是并行开发的,也就是说硬件设计,底层软件设计,应用软件设计是同步进行的.比如说在开发板上调试模块驱动,在其他平台上调试应用再移植到目前这个平台等. 要想开发的应用程序在不同 ...

  • 深度:嵌入式系统的软件架构设计!

    来源 :嵌入式云IOT技术圈,作者:veryarm 1. 前言 嵌入式是软件设计领域的一个分支,它自身的诸多特点决定了系统架构师的选择,同时它的一些问题又具有相当的通用性,可以推广到其他的领域. 提起 ...

  • 一文讲解业务系统软件架构设计核心内容和逻辑

    原创人月聊IT2020-07-21 16:45:16 作者:人月神话,新浪博客同名 简介:多年SOA规划建设,私有云PaaS平台架构设计经验,长期从事一线项目实践 今天准备再详细讲解下业务系统软件架构 ...

  • 好的软件架构设计

    https://www.cnblogs.com/kissed/p/5983780.html 什么是软件架构 前言:软体设计师中有一些技术水平较高.经验较为丰富的人,他们需要承担软件系统的架构设计,也就 ...

  • 软件架构设计的颗粒度

    引子 最近给某客户咨询时,与架构工程师讨论了软件架构设计的颗粒度问题. 软件架构工程师纠结的问题是: 功能安全ISO26262标准,以及某OEM要求中,都提到了软件架构设计时需要识别SW Unit. ...

  • 软件架构设计分层模型和构图思考

    今天谈下架构设计中的分层思维和分层模型以及基于分层思维下的架构构图逻辑. 架构思维概述 对于架构思维本身仍然是类似系统思维,结构化思维,编程思维等诸多思维模式的一个合集.由于架构的核心作用是在业务现实 ...