• home > SpecialTopic > book > technical >

    软件架构师书籍改看什么书?

    Author:[email protected] Date:

    Software Architecture,这个领域没有什么 "畅销书 ",可能读者中本来就是开发设计人员与项目经理占了多数,真正定位为架构师而且做的也是架构师工作的不多吧。

    一、Software Architecture篇

         这个领域没有什么"畅销书",可能读者中本来就是开发设计人员与项目经理占了多数,真正定位为架构师而且做的也是架构师工作的不多吧。

       1.《Software Architect Bootcamp--软件架构师教程》

        架构师新手训练营,可惜常以Corba做例子。第2版国内还没有翻译,只好看完中文的第一版再去看电子版了。
       
      2. 《Large-Scale Software Architecture-A Practical Guide using UML--大型软件体系结构:使用UML实践指南》
       
    如果看不惯上一本,可以改以这本作为入行指南。

      

     3. 《The Art of Software Architecture: Design Methods and Techniques--软件体系结构的艺术》

        薄薄的一本,架构理论的抽象与提升。
     
     

    4.《Documenting Software Architectures: Views and Beyond--软件构架编档》

         第13届JOLT大奖作品,市面上介绍UML描述架构的书很多,但捕获架构的过程,为什么这样捕获的书籍就少了,所以它拿JOLT。
     

       二、架构模式篇

        GOF23属于开发人员的Pattern,架构师同样也有架构师的Pattern。

    1. 《Head First Design Patterns》 

          最好的GOF23经典设计模式讲解。
     。

    2. 《Patterns of Enterprise Application Architecture--企业应用架构模式》

        Martin Fowler经典。
      


    3. 《Analysis Patterns: Reusable Object Models --分析模式》
        Martin Fowler作品,但需要刚好有那个经验的人才看得进去。


    4. 《Domain-Specific Application Frameworks: Frameworks Experience by Industry--特定领域应用框架:行业的框架体验》
     介绍了特定领域特定框架的设计,我自己最喜欢看人家的设计与思考。

         


    三、特定领域模式篇

    1. Java EE领域 

       《Effective Enterprise Java--中文版》    

        Neward, Ted作品。

       《Expert One-on-One J2EE Design and Development--J2EE设计开发编程指南》

         Rod Johnson作品,依然使用J2EE的倒霉架构师需读。



             


    2. SOA/ESB领域 
    《Enterprise Integration Patterns: Designing, Building, and Deploying Messaging Solutions--企业集成模式:设计、构建及部署消息传递解决方案》


      


    3. 网络与后台服务编程领域
    《Pattern-Oriented Software Architecture, Patterns for Concurrent and Networked Objects, Volume 2--面向模式的软件体系结构 卷2:用于并发和网络化对象的模式》

    Pattern-Oriented Software Architecture: Patterns for Resource Management, Volume 3--面向模式的软件体系结构卷3:资源管理模式》

        著名的POSA2与POSA3。

        

    四、RUP/UML 篇

        除了RUP、UML、4+1视图,架构师们还可以遵循很多的设计方式,但UML仍然是架构师们的通用语言,RUP还是架构师职责最清晰的任务执行流程。

    1. RUP最好的书其实是那份《RUP-软件开发团队的最佳实践》加上 RUP2003.6.15 中文版自带的架构师视角的文档,还有空可以看看《The Rational Unified Process:An.Introduction.第3版》


    2. UML随便看一份电子书也能入门了,语法方面不需要专门买书。但教人如何画好UML的《The Elements of UML Style--UML风格》就很必要,可惜国内没有翻译第2版。



    五、闲书篇

    1.《Code Complete 2--代码大全2》 

        一本你教育小弟时的代言人。
      

    2.《The Pragmatic Programmer--程序员修炼之道:从小工到专家》

        一本你启发小弟的代言人。
     


    3.《The Art of Unix Programming --UNIX编程艺术》

     

    六、高效读书心得

       刚好Head First系列开头都有一段教人如何读书的话,结合自己的经验整理如下:

    1.尽量阅读中文版
      虽然有人英文很强,有的翻译很差,但AnyWay 中文阅读与理解的时间,略读与快速定位感兴趣内容的速度还是要快一些。
      
    2.即时批注、总结笔记与交流
      虽然爱书,但发现最有效的读书方式还是不断的制造脂批本,读书时在重要的文字下划线,把自己的心得写在页旁。
      读完后,把上面的划线与批注,用自己的语言重新整理表述。有人喜欢用MindManager,我还是习惯纯文本123。
      最好在明天复习一次,或者拿来与人讨论。
     
    3.大量思考或重复记忆
      看书最郁闷的事情就是看完之后脑袋空空了。偏重技术的书还好点,虽然看的时候可能很辛苦,但就像学会了骑单车之后,再骑的时候总是会的;而偏重设计与管理的书,最容易的事情就是看的时候很快,看完没什么留下到项目实践中。
      所以,我们不能以看小说的速度来看设计书,要寻找思考的机会,思考是最好的记忆。
      如果实在没有思考的topic,就只有大量的重复记忆,重复多遍直到无意识的记忆。 
      
    4.人体工学
      那些见缝插针的时间与地点不是看这个书单的好地方。
      环境不要有电视,音乐等强输入源,而微风阳光鸟语等弱输入源则有助活跃大脑。
      看书时大量的喝水。
      如果发现自己的大脑已经疲累,已经在浮光掠影的翻看,就要休息。
      留给大脑消化的时间,看完书不要接着看其他有难度的书或事情。




    作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从。我想就我自己读过的技术书籍中挑选出来一些,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水平的Java程序员们。

    一、Java编程入门类

    对于没有Java编程经验的程序员要入门,随便读什么入门书籍都一样,这个阶段需要你快速的掌握Java基础语法和基本用法,宗旨就是“囫囵吞枣不求甚解”,先对Java熟悉起来再说。用很短的时间快速过一遍Java语法,连懵带猜多写写代码,要“知其然”。

    1、《Java编程思想》

    在有了一定的Java编程经验之后,你需要“知其所以然”了。这个时候《Java编程思想》是一本让你知其所以然的好书,它对于基本的面向对象知识有比较清楚的交待,对Java基本语法,基本类库有比较清楚的讲解,可以帮你打一个良好的Java编程基础。这本书的缺点是实在太厚,也比较罗嗦,不适合现代人快节奏学习,因此看这本书要懂得取舍,不是每章每节都值得一看的,挑重点的深入看就可以了。

    2、《Agile Java》中文版

    这本书是出版社送给我的,我一拿到就束之高阁,放在书柜一页都没有翻过,但是前两天整理书柜的时候,拿出来一翻,竟然发现这绝对是一本好书!这本书一大特点是以单元测试和TDD来贯穿全书的,在教你Java各种重要的基础知识的过程中,潜移默化的影响你的编程思维走向敏捷,走向TDD。另外这本书成书很新,以JDK5.0的语法为基础讲解,要学习JDK5.0的新语法也不错。还有这本书对于内容取舍也非常得当,Java语言毕竟类库庞大,可以讲的内容太多,这本书选择的内容以及内容的多寡都很得当,可以让你以最少的时间掌握Java最重要的知识,顺便培养出来优秀的编程思路,真是一本不可多得的好书。

    虽然作者自己把这本书定位在入门级别,但我不确定这本书用来入门是不是稍微深了点,我自己也准备有空的时候翻翻这本书,学习学习。


    二、Java编程进阶类

    打下一个良好的Java基础,还需要更多的实践经验积累,我想没有什么捷径。有两本书值得你在编程生涯的这个阶段阅读,培养良好的编程习惯,提高你的代码质量。

    1、《重构 改善既有代码的设计》

    这本书名气很大,不用多介绍,可以在闲暇的时候多翻翻,多和自己的实践相互印证。这本书对你产生影响是潜移默化的。

    2、《测试驱动开发 by Example》
    本书最大特点是很薄,看起来没有什么负担。你可以找一个周末的下午,一边看,一边照做,一个下午就把书看完,这本书的所有例子跑完了。这本书的作用是通过实战让你培养TDD的思路。

    三、Java架构师之路

    到这个阶段,你应该已经非常娴熟的运用Java编程,而且有了一个良好的编程思路和习惯了,但是你可能还缺乏对应用软件整体架构的把握,现在就是你迈向架构师的第一步。

    1、《Expert One-on-One J2EE Design and Development》

    这本书是Rod Johnson的成名著作,非常经典,从这本书中的代码诞生了springframework。但是好像这本书没有中译本。

    2、《Expert One-on-One J2EE Development without EJB》

    这本书由gigix组织翻译,多位业界专家参与,虽然署名译者是JavaEye,其实JavaEye出力不多,实在是忝居译者之名。

    以上两本书都是Rod Johnson的经典名著,Java架构师的必读书籍。在我所推荐的这些书籍当中,是我看过的最仔细,最认真的书,我当时读这本书几乎是废寝忘食的一气读完的,有小时候挑灯夜读金庸武侠小说的劲头,书中所讲内容和自己的经验知识一一印证,又被无比精辟的总结出来,读完这本书以后,我有种被打通经脉,功力爆增的感觉。

    但是后来我看过一些其他人的评价,似乎阅读体验并没有我那么high,也许是因为每个人的知识积累和经验不同导致的。我那个时候刚好是经验知识积累已经足够丰富,但是还没有系统的整理成型,让这本书一梳理,立刻形成完整的知识体系了。

    3、《企业应用架构模式》

    Martin的又一本名著,但这本书我只是泛泛的看了一遍,并没有仔细看。这本书似乎更适合做框架的人去看,例如如果你打算自己写一个ORM的话,这本书是一定要看的。但是做应用的人,不看貌似也无所谓,但是如果有空,我还是推荐认真看看,会让你知道框架为什么要这样设计,这样你的层次可以晋升到框架设计者的角度去思考问题。Martin的书我向来都是推崇,但是从来都没有像Rod Johnson的书那样非常认真去看。

    4、《敏捷软件开发原则、模式与实践》
    Uncle Bob的名著,敏捷的经典名著,这本书比较特别,与其说是讲软件开发过程的书,不如说讲软件架构的书,本书用了很大篇幅讲各种面向对象软件开发的各种模式,个人以为看了这本书,就不必看GoF的《设计模式》了。


    四、软件开发过程

    了解软件开发过程不单纯是提高程序员个人的良好编程习惯,也是增强团队协作的基础。

    1、《UML精粹》

    UML其实和软件开发过程没有什么必然联系,却是软件团队协作沟通,撰写软件文档需要的工具。但是UML真正实用的图不多,看看这本书已经足够了,完全没有必要去啃《UML用户指南》之类的东西。要提醒大家的是,这本书的中译本翻译的非常之烂,建议有条件的看英文原版。

    2、《解析极限编程 拥抱变化》XP

    这是Kent Beck名著的第二版,中英文对照。没什么好说的,必读书籍。

    3、《统一软件开发过程》UP

    其实UP和敏捷并不一定冲突,UP也非常强调迭代,测试,但是UP强调的文档和过程驱动却是敏捷所不取的。不管怎么说,UP值得你去读,毕竟在中国真正接受敏捷的企业很少,你还是需要用UP来武装一下自己的,哪怕是披着UP的XP。

    4、《敏捷建模》AM

    Scott Ambler的名著,这本书非常的progmatic,告诉你怎么既敏捷又UP,把敏捷和UP统一起来了,又提出了很多progmatic的建议和做法。你可以把《解析极限编程拥抱变化》、《统一软件开发过程》和《敏捷建模》这三本书放在一起读,看XP和UP的不同点,再看AM是怎么统一XP和UP的,把这三种理论融为一炉,形成自己的理论体系,那么你也可以去写书了。


    五、软件项目管理

    如果你突然被领导提拔为项目经理,而你完全没有项目管理经验,你肯定会心里没底;如果你觉得自己管理项目不善,很想改善你的项目管理能力,那么去考PMP肯定是远水不解近渴的。

    1、《快速软件开发》

    这也是一本名著。可以这样说,有本书在手,你就有了一个项目管理的高级参谋给你出谋划策,再也不必担心自己不能胜任的问题了。这本书不是讲管理的理论的,在实际的项目管理中,讲这些理论是不解决问题的,这本书有点类似于“软件项目点子大全”之类的东西,列举了种种软件项目当中面临的各种问题,以及应该如何解决问题的点子,你只需要稍加变通,找方抓药就行了。


    六、总结

    在这份推荐阅读书籍的名单中,我没有列举流行的软件框架类学习书籍,例如Struts,Hibernate,Spring之类,也没有列举AJAX方面的书籍。是因为这类书籍容易过时,而上述的大半书籍的生命周期都足够长,值得你去购买和收藏。


    转载本站文章《软件架构师书籍改看什么书?》,
    请注明出处:https://www.zhoulujun.cn/html/res/book/technical/2016_0316_7711.html