软件架构核心问题和关键决策探讨.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
软件架构核心问题和关键决策探讨

软件架构核心问题和关键决策探讨   摘要:架构是实现软件相关服务和基本业务系统的重要阶段,而架构决策又是这一阶段的核心。为了帮助理解软件架构的本质和架构实现,概述了架构的基本过程,介绍了系统分解原则,重点讨论了架构决策的范围及主要决策内容。在架构决策框架中解释了实现架构决策的3个层次,以及各层次可以使用的UML图表等工具。掌握好这些方法能有效减少软件架构的盲目性,为软件设计与实现提供规范与指导。   关键词:   软件架构;架构决策;系统分解   DOIDOI:10.11907/rjdk.172989   中图分类号:TP301   文献标识码:A 文章编号:1672-7800(2017)012-0057-03   Abstract:Architecture is an important stage for implementing software-related services and basic business systems, and architectural decisions are the core of this stage. To help understand the full essenceof the software architecture and its implementation, this paper summarizes the basic process of architecture, introduces the system decomposition principle, and focuses on the scope of architectural decisions and major decisions. The three levels of architectural decision are explained in the decision framework, as well as tools such as UML diagrams that can be used at all levels. In summary, mastering these methods can effectively reduce the blindness of software architecture and provide specifications and guidance for software design and implementation.   Key Words:software architecture; architecture decision; system decomposition   0 引言   软件在人类社会活动中发挥着不可估量的作用,软件工程旨在研究软件系统架构、开发、运行、维护、演化的创新方法以提高效率和质量[1]。软件并非开发商为客户提供的第一样东西,但它的好坏会直接影响客户的感受。无论公司大小,对软件的依赖程度都在急剧增加。不管公司关注的战略重点是什么,软件架构已经成为一种能力,掌握得好将极大提升公司的实力和水平,否则会严重削弱项目或系统构建[2]。本文通过视图帮助架构师解决软件架构的关键问题,从而使其概念具有可操作性。   1 软件架构概述   以往软件架构所关注的核心问题是系统的复杂性,然而今天许多系统具有与摩天大楼媲美的复杂性。因此,软件设计问题超出了算法和数据结构,设计和指定整个系统结构就是软件架构级别的设计。很明显,复杂性是软件架构必须解决的一个关键问题[3]。主要体现在两方面:①知识难驾驭,如构建系统的复杂性、规模、依赖关系和采用技术等;②管理难驾驭,如构建系统的组织和流程、参与构建系统的人数、项目的依赖关系、外包、地理分布的团队等[4]。   分解系统可以解决复杂性问题,但是怎么分片?好的分解满足组件之间松散耦合的原则,通过干净接口,合理地将其划分为可单独处理的独立部分以简化问题。该结构必须支持系统所需的功能或服务。因此,必须考虑系统的动态行为,还要有必要的基础设施支持这些服务[5]。   如何将切片结合在一起是界面与各个部分之间的关系问题。保持系统完整性的同时,也需要保证这些切片组成的系统具有良好适应性。这些品质或特性对系统具有分散或系统性影响,因此是交叉分割的关注点。这不是一个孤立的问题,因为分解是由其它问题驱动的,无论怎样分割,多个部分都必须合作解决这些关注点。为了有效地解决跨部门关切的问题,必须首先在范围更广的层面上处理问题。许多系统质量(非功能性要求或服务级协议)具有这种性质,包括性能、安全性和互操作性要求。例如,为了使图像更加复杂,可能会与系统质量发生冲突,因此要

文档评论(0)

130****9768 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档