软件架构设计(一):软件架构概念_软件开发概念结构设计_丨许晨丨的博客-程序员秘密

技术标签: 软件架构  

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

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的信息以更新自身。
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Mrxuchen/article/details/111151120

智能推荐

DATEPART() 函数_datepart函数_月亮哥的博客-程序员秘密

SQL Server DATEPART() 函数 定义和用法DATEPART() 函数用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。语法DATEPART(datepart,date)date 参数是合法的日期表达式。datepart 参数可以是下列的值: datepart缩写年yy, yyyy季度qq,

Spring Boot 之FilterRegistrationBean --支持web Filter 排序的使用_你走开``的博客-程序员秘密

Spring Boot 之FilterRegistrationBean  –支持web Filter 排序的使用Spring 提供了FilterRegistrationBean类,此类提供setOrder方法,可以为filter设置排序值,让spring在注册web filter之前排序后再依次注册。  写一个普通的filter:[java] view plain copy print?pac

Linux服务器集群系统(三)_linux服务器集群分类_p312011150的博客-程序员秘密

LVS集群中的IP负载均衡技术章文嵩 ([email protected]) 2002 年 4 月本文在分析服务器集群实现虚拟网络服务的相关技术上,详细描述了LVS集群中实现的三种IP负载均衡技术(VS/NAT、VS/TUN和VS/DR)的工作原理,以及它们的优缺点。1.前言在 前面文章中,讲述了可伸缩网络服务的几种结构,它们都需要一个前端的负载调度器(或者多个进行主从备份)...

VGG网络:网络改造的首选基础网络_vgg改进_essenge的博客-程序员秘密

import torch.nn as nnimport torchclass VGG(nn.Module): def __init__(self, features, num_classes=1000, init_weights=False): super(VGG, self).__init__() self.features = features self.classifier = nn.Sequential( nn.D

Linux【实操篇】—— Shell函数、Shell编程综合案例(定时备份数据库)_shell编程综合设计_敬 之的博客-程序员秘密

Linux 操作系统Shell编程快速入门、shell函数,Shell编程综合案例(定时备份数据库)。

【Vue组件自定义事件详解】_小田『开心馆』的博客-程序员秘密

本篇文章介绍了组件自定义事件的原理以及使用的方法,在实际开发中,组件的自定义事件也是一个小技巧,能有效提高开发的效率

随便推点

多智能体中的图论——图论中的定义(一)_多智能体图论_autotian的博客-程序员秘密

目前人工智能分为:大数据智能,跨媒体智能,群体智能,混合增强智能,自主无人系统五类,若想要深入群体智能则图论的基础是非常必要的!一、引言1.1、专业词汇:distributed network:分布式网络 distributed multiagent network:分布式多智能体网络boids model:柏兹模型(类鸟型) topology:拓扑结构directed ...

盘点项目管理工具DHTMLX Gantt 的常见问题_dhtmlxgantt_爱分享的小妮子的博客-程序员秘密

可满足项目管理应用程序的大部分开发需求,具备完善的甘特图图表库,功能强大,价格便宜,提供丰富而灵活的JavaScript API接口,与各种服务器端技术(PHP,ASP.NET,Java等)简单集成,满足多种定制开发需求。默认情况下,任务的最后一天不包括在任务的持续时间中,但可以更改默认行为并将最后一天包括在持续时间中。如果您已经安装了许可的专业版甘特图,但仍然看到评估期已过期的消息,这意味着您的应用程序中某处有试用版。为了确保所描述的行为对您的情况是真实的,您可以在浏览器的导航面板中检查 URL。

ABAP (转)BDC常见问题_abap bdc_yiyuzz的博客-程序员秘密

BDC在FICO模块是经常用到的,用于批量过账程序时使用的,但是稳定性不如使用BAPI的好,但是BDC可以有多种T-CODE进行过账,也有不同的模式,功能也不错,但是在写程序或者是出现问题的时候需要考虑下面几个问题:1、可以在程序加入BDC的模式选择,默认为N模式,但是可以选择A模式,方便调试。当然这个也可以debug进去之后进行改值。2、LOOP里面有call BDC的情况,在每一次ca...

iw 命令_斷點1的博客-程序员秘密

关于 iwiw 是一种新的基于 nl80211 的用于无线设备的CLI配置实用程序。它支持最近已添加到内核所有新的驱动程序。采用无线扩展接口的旧工具iwconfig已被废弃,强烈建议切换到 iw 和 nl80211。像Linux内核的其余部分,iw 仍处于开发阶段。功能被随时添加。 iw 的唯一文档就是此页和“iw help”的输出。 请帮助扩大这个

提高级:初等数论 威尔逊定理_威尔逊定理扩展形式_dllglvzhenfeng的博客-程序员秘密

数论四大定理之威尔逊定理数论四大定理之威尔逊定理 - 简书威尔逊定理及其证明 - clockwhite - 博客园数论四大定理之威尔逊定理_L__ear的博客-程序员秘密_威尔逊定理威尔逊定理威尔逊定理_Michael_Li的博客-程序员秘密_威尔逊定理威尔逊定理_jkchen's Haven-程序员秘密威尔逊定理 数论威尔逊定理 数论_初学者-程序员秘密_威尔逊定理如何用最简单明了的话语解释威尔逊定理吗?哪种证明威尔逊定理的方法最简单?如何用最简