首页 > 代码库 > 《架构之美》阅读笔记01
《架构之美》阅读笔记01
一、阅读内容
第一章架构概述
第二章两个系统的故事:现代软件神话
二、笔记总结
(1)什么是软件架构?
其实在好多学科中都用到了“架构”这个词,大都表达了对所创造作品的描述,或者是对创造过程的计划。但是在软件专业中还有更具体的表达。软件架构不是一个简单的实体,软件架构师需要用多分文档来对软件的行为和结构进行描述,以此来形成软件架构。《软件架构实践》一书对软件架构的规范化定义是这样的,一个程序或计算机系统的软件架构是系统的一种结构或一组结构,包含了软件元素、软件元素外部可见的属性以及元素之间的联系。这里的外部可见的属性指的是其他元素对该元素可以做出的假定,比如所提供的服务,执行的特征或者错误处理等等。实际上,软件架构对软件设计进行了适当的抽象化,使得架构师更关注软件设计中的某些方面。
(2)软件架构师要做什么?
这里就用到了我们在软件需求分析课堂上所学到的知识了。这里只突出强调两点,要关注利益相关人员的需求,以及同时做到关注软件的功能和品质。每一个或者说每一类的利益相关者对软件系统的品质关注点是不一样的,软件架构师需要同这些利益相关者展开协作,理解这些品质关注点和约束,并为这些品质关注点排列优先级。尽管许多架构都能满足功能需求,但是能满足品质需求的却很少。架构师需要对软件系统形成全面的理解,在软件设计中做出明智的决定。
(3)什么是好的软件架构?
其实创建软件架构的过程就是一个取舍的过程,对于一组给定的功能需求和品质需求,是没有唯一正确的软件架构的,我们需要从经验中对架构进行评估。首先一个好的软件架构须让系统的每一个用户都能理解该系统的架构,如果不能让一个人理解软件的架构的话,那么这个软件的架构一定不是好的架构。其次,在使用架构之前必须先构建,使用一个好的架构一定是可构建的,可扩展的。最后也是最重要的一点,好的架构必须从软件设计到构建到使用的全过程使得所有人都满意,这里包含了三个层次。第一是能使软件开发人员的工作变得简单。第二是使软件测试人员的工作变得轻松,最后是让使用软件的用户拥有良好的使用体验。
《架构之美》阅读笔记01
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。