国内我们对架构师,项目经理,开发经理或者是技术总监这类职业定位普遍不都不清晰,很多的情况是“能者多劳”,一人身兼数职。达尔文的理论在我们的行业是绝对适用的,我从进入这个行业开始我就不甘于成为淘汰者,而我也由心地热爱着这个行业很年前我就立志要成为架构师(当年流行叫:系统分析员 )这目标进发。回首这10几年的磨练,我总结了一下一名合格的架构师应该具备哪一些方面的能力以及怎么才能得到这些能力
一、编码能力
架构师是一个职业,是一种经历了各种磨练与长年开发经验积累出来的。另外我一直认为:不会编码的架构师不是一个好的架构师。我见过很多所谓的架构师完全不懂编码,但总喜欢拿着架构说事。但从严格来说他们并不属于“软件架构师”的范畴,充其量只能算是个“系统架构设计师”,遇到这样的”架构师“我总喜欢说一句话:”Don’t tell me the concepts show me the code!“。
不参与编码并不代表不会编码,如果没有过硬的开发基础,巨量的编码时间积累为基础,在设计软件时一定会忽略非常多的细节,而这将会直接影响到整个项目的成败,试想想当项目经理按照架构师设计的软件蓝图订制开发计划与安排项目资源时由于“蓝图”内存有大量未确定的风险因素,以及由风险触发后所带来的不可预知的结果,最后项目是否能成功 ?
- 多看 - 多看别人的代码,从别人的代码中读出软件的架构与设计的设计思路
- 多学 - 掌握各种语言,不要偏执于某一技术阵形,不管java, .net , phyon 还是javascript每种语言都有其优缺点,成为一名语言控,从语言本身学习与理解语言设计者的思想。
- 多做 - 疯狂编码,从时间与实践中去体验与领悟,工多艺熟。
- 勇敢 - 严格要求自己不要写出”发臭“的东西,勇敢地重构!让代码变得优雅,易读充满你的设计思想。
二、表达力
世界上最难的两件事是:将别人口袋的钱放到自己的口袋里面;将自己脑子的想法完整放到别人的脑子里面。
我认为一份成功的设计是 ”能让不同层面的人都能看得懂“。为什么这样说?那么得了解谁需要看设计,又是出于何目的来看设计。
- 销 售 - 从设计中寻找卖点与特色,丰富销售方案和定制预售计划。
- 项目经理 - 根据设计进行时间估算、项目资源准备与工作分解。
- 开 发 - 根据设计要求进行技术准备、开发环境、编写DEMO以及最终编码 。
- 测 试 - 根据设计划分测试粒度、准备测试环境、定制测试计划
不同的开发方法与开发流程都会有不同的设计文档要求,而受众无非也是上述几种。作为项目/软件的设计者,能清晰地向受众准确地传达自己的设计思路就显得极其重要。这里指表达不是指嘴上的功底,更多的是在工具的掌握能力与文字的表达能力。使用不同的工具表达向不同的受从表达相同的理念,这基实是对架构设计的一种验证,这种沟通与表达能有效地融合不同角度的观点,也能让架构师能更深入地理解自己的设计方向。
要面对如此多的复杂性应该如何来锻炼自己的表达性呢?
多与人沟通,多参与头脑风暴
练习用人类语言表达“非人类”的专业知识。一张用铅笔画的框图往往比一个使用专业UML设计工具做出来的设计更容易让人理解。 UML为作架构师基本上是必修课,也是辅助架构师思维的工具,但对于不懂UML的那就是“非人类”的文档,设计是给人看的,别人看不懂再专业再标准化的设计也只能沦为废纸。
培养测试先行的习惯 - 在设计时多写范例与测试,在很大程度上可以减少设计误区和验证被实现的可行性。这样可以在将设计交付给开发、测试后节约大量的沟通时间。
三、拥抱变化
正如XP(极端编程)中所说:“世界上唯一不变的就是变化”。拥抱变化、预测变化、控制变化不单纯是优秀开发人员的和项目经理的要求同样也是架构师一种重要的能力。
“变” 我的理解 设计中的“变” 就是 “可定制化” 的要求,可定制化程度越高系统/项目的可扩展性就越强。架构师就是需要锻炼的是控制这种变化的范围与程度,“变”是双刃剑,允许过多的变化就会造成“过度设计”,出现一大堆“未来可能使用的功能”;过于封闭则会变得僵化难以适应新的要求。
“不变”这里所说的“不变”也只是相对而然,在系统/项目中相对不变的就应该是“核心”或者是“基础框架”,举最简单的例子就是 .net framework 就是其中一者,虽然它会不断发展,增强功能。但其基础核心设计理念与架构也从来没有发生过质的改变。更具体的一点来说“不变”的是规则、用法和基础设计理念。 我认为学习控制变化的最佳方法是多看出色的类库或系统,多问为什么这样做,理解原设计师的想法。经过一定时间的积累,随着对“变化”观察的增多,自然而然会在自已的设计中按设计要求将”变“与”不变“应用得当。
四、方法论
针对架构设计的方法论众多,应该如何选择?我也读过很多的相关书籍,我只选最实用的,这里我推荐几本书。
《设计模式》- 要读懂、活用,我读了10几年每次都可以从中学到不一样的想法,将其应用于架构内可以极大地简化很多复杂的问题。
《Java 编程思想》 - 谈面向对象方面最好的其中一本书,提高面向对象的设计能力会有很大帮助 《Refactoring》- 重构不单单是一种做法和程序员才关心的事。重构重于意识与思维完全可以用于架构设计 。
《eXtreme Programming》- 虽然讨论的是开发方法,但它最能诠释什么是”变化“。
方法论的实践与应用也需要时间磨合并融会贯通,它们给予我们更多的是理念与意识,一定要避免走进为实践方法论而设计的误区。
五、学习能力
对于普通程序员来说,成为高级架构师的门槛主要有以下几点:
1、错误的学习方法。在技术日新月异的今天,谁在单位时间学到的知识更多,谁的学习方法更高效,谁就获得更强的竞争优势。而很多程序员在工作中,还用着学校时的学习方法,非常低效,公司不是学校,啃书本的学习方法已不再有效。
2、完整的知识体系。没有形成系统化的知识架构,最重要的是不知道哪些技术需要重点掌握,学习时频繁踩坑,最终浪费大量时间。
3、对编程的认知。顶级程序员和平庸程序员,本质区别是遇到问题时的思考方式,这就是所谓的顶级程序员思维,一种高效解决问题的思维方式。这种思维方式,不是读几本Java书能学到的,而需要经过大量项目实战,才能总结提炼出来。
4、差的学习环境。很多程序员的学习环境很差,在公司经常加班,工作几年后,发现自己除了更熟悉公司业务外,能力没有得到半点提升,或周末基本不学习,而是出去玩。这么差的自制力和学习环境,很难让能力提到大的提升。
构建完整的知识体系感兴趣的朋友可以来参考下我从业十余年总结2018年互联网公司中最主流的学习路线: 这是Java程序员的一个架构梦,我专门设立了一个Java架构学习的群:619881427里面找朋友上传的都是下列图片中的技能知识点,如果感兴趣你可以进来瞅一瞅,可以免费领走你的架构师学习资料。
image
image
image
image
image
image
既然有梦想,干嘛你不来!