zoukankan      html  css  js  c++  java
  • 《架构漫谈》读书笔记

           新学期,在老师的推荐下,我精读了《架构漫谈》九篇博客。刚好对本学期开设的软件架构这门课程有了一个学习的方向,同时,对于软件架构知识体系有了全面的了解。下面是我在阅读过程中的几点体会。

           架构漫谈逐步讨论什么是架构、怎样做好架构、软件架构如何落地、如何写好程序等问题。首先,要搞清楚什么是架构,什么又是软件建构。什么是架构?我简单的理解为一种解决问题的模板。深入了解发现架构是为了解决由人执行的工作、解决分工合理明确、提高生产效率的问题。架构对提高生产效率是很有帮助的?那么,怎么提高生产效率呢?除了科学技术带来的生产力的提高之外,剩下就是人的问题了。由于每个人的时间精力有限,并且在同一时间一般只能专注做一件事,因此就有了分工。分工的合理明确就提高了生产效率。由此引用架构漫谈中的定义就不难理解了。架构是根据要解决的问题,对目标系统的边界进行界定,并对目标系统某个原则进行切分,切分的原则,要便于不同的角色,对切分出来的部分,并行或串行开展工作,一般并行才能减少时间。并对这些切分出来的部分,设立沟通机制。

          架构的产生需要五个条件同时成立。

    1. 必须由人执行的工作(不需要人介入,就意味着不需要改造,也就不需要架构了)

    2. 每个人的能力有限(每个人都有自己的强项,个人的产出受限于最短板,并且由于人的结构限制,同时只能专注于做好一件事情,比如虽然有两只眼睛,但是只能同时专注于一件事物,有两只手,无法同时做不同的事情。 虽然有少部分人可以左手画圆右手画框,但是不是普遍现象)

    3. 每个人的时间有限(为了减少时间的投入,必然会导致把工作分解出去,给擅长于这些工作的角色来完成,见2,从而缩短时间)

    4. 人对目标系统有更高的要求(如果满足于现状,也就不需要进行架构了)

    5. 目标系统的复杂性使得单个人完成这个系统,满足条件2,3(如果个人就可以完成系统的提高,也不需要别的人参与,也就不需要架构的涉及,只是工匠, 并且一般这个工作对时间的要求也不迫切。当足够熟练之后,也会有一定的架构思考,但考虑更多的是如何提高质量,提高个人的时间效率)

     

     

     

     

     

     

     

     

           如果一个人在工作中,只是致力于完成自己的工作,以做好自己的工作为主要目标,那么最多只能成为一个工匠,无法成为一个架构师。因为这个过程解决的还是自己的问题,并没有时间的压力,可以随意什么时候做完都可以。 要成为架构师,必须要能够看清楚,我们要解决的是别人的问题,不是自己完成工作的问题。因为仅仅是完成了自己的工作,也并不一定就解决了别人的问题。如果别人的问题没有解决–即使我们认为自己的工作完成了–我们的工作实际也没完成,因为我们工作是否完成,是别人说的算的,不是我们自己。只有做到这一点,才能在自己所服务的领域建立起自信,成为一个合格的架构师。 由架构出现逻辑,逻辑出现问题,必然导致架构无法快速的横向扩展和分拆,并且增加了修改的成本,这些是不符合开发人员以及业务的利益的。 要学会理清技术、业务和架构的关系:我们要学会怎么处理业务、技术还有架构的关系。那么什么是技术要解决的是人类自己的问题,这就是业务,实际就是人类的利益。架构师应该承担起解决业务问题的这个角色来,专注于Business Domain和软件本身的架构,让技术人员致力于为业务在计算机中跑起来而努力。只有把这两者很好的结合起来,才能更好地完成业务的目标,才会让软件更好地服务于大家。最终一定会得到一个很好的软件架构,令软件开发团队和业务部门都能够很好地开展工作并降低成本。准确识别采用什么技术的能力,也是架构师所要具备的能力之一。考虑的主要因素也是长期的成本和收益。

    1.什么是软件架构 
    软件架构实际上包括了:代码架构,以及承载代码运行的硬件部署架构。实际上,硬件部署架构最终还是由代码的架构来决定。因为代码架构不合理,是无法把一个运行单元分拆出多个来的,那么硬件架构能分拆的就非常的有限,整个系统最终很难长的更大。

     

    所以我们经常会听说,重写代码,推翻原有架构,重新设计等等说法,来说明架构的进化。这实际上就是当初为了完成任务,没有充分思考所带来的后果。这也并不是架构进化的事情,而是个人对问题领域的逐渐深入理解的过程。所以有必要再讨论一下,代码的架构应该是怎样的。

     

    2.架构师思维

     

    抽象 
    分层 
    分拆(或划分职责) 
    建立内部流程 
    学会了技术并不代表能够解决问题

     

    3.步骤 
    学习业务知识 
    对业务进行建模

     

    4.架构师的前提条件

     

    把完成别人工作当成自己的最大利益,帮助别人解决问题 
    技术领域、业务领域

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    在awk里引用shell变量(支持正则)
    python模块pyautogui
    一个完整的搜索系统
    信息检索笔记(9)再论文档评分
    信息检索导论学习笔记(8)向量空间模型
    搜索引擎查询扩展
    信息检索笔记(10)Lucene文档评分机制
    Lucene的分析过程
    信息检索导论学习笔记(7)文档评分、词项权重计算
    信息检索导论学习笔记(5)
  • 原文地址:https://www.cnblogs.com/zyx111/p/8530252.html
Copyright © 2011-2022 走看看