精通型程序员的特点

你知道有能力胜任和精通之间的区别是什么吗?

这听起来像一个很难回答的问题,因为这两者似乎意味着同样的事情。但它们之间的微妙区别至关重要。

有能力胜任是指有足够的经验和知识来完成各项工作;精通涉及知道为什么你要用某种方式来做事情,以及如何融入到大局中。换句话说,精通型从业者总是有能力胜任,但反之可能不成立。

Dreyfus Model of Skill Acquisition》非常详细地涵盖了这个主题。虽然标题听起来有点学术化,但是论文非常平易近人。

我建议阅读原始资源材料以便于能更好地纵观从初学者到专家的历程。在这篇文章中,我将重点放在大多数软件开发人员都会碰到的瓶颈:跨越从胜任到精通的沟壑。

因此,首先,我们要知道的是,这里胜任的工作定义是“我知道该怎么做” ——虽然过于简化,但非常贴合我们的需要。公平地说,不管你工作在什么样的职业,知道怎么做是非常重要的。如果你是一个程序员,学习该怎么做是你工作的重要部分:

  • --我需要知道如何使用版本控制
  • --我需要知道如何使用一种一致的编码风格
  • --我需要知道如何建立一个持续集成服务器
  • --我需要知道如何查询数据库
  • --我需要知道如何实现响应式布局
  • --我需要知道如何使用服务API

不要误会我的意思:知道怎么做,是非常重要的。不要停止去学习怎么做,否则,你很快就会发现自己会失去这份工作。

但是,处于两者之间的程序员往往会被卡住(很多因此而裹足不前),而他们被卡住的地方被认为是初学者和专家之间的差别,可以用来衡量你知道多少东西。这里只有一半是正确的,并且它强调的是不那么重要了的一半。

这正是精通的来源。并且精通的实质是“为什么你要用某种方式做事” -——是单独理解问题的每个部件与理解部分是如何融入整体之间的差异。

胜任和精通之间的差距可以解释为什么如此多的人想要攀登高层次的编程思想,例如设计模式

一个有能力胜任的程序员当然可以阅读Memento Pattern并理解如何去实现它。他们或许甚至能够确定可以应用模式的场景(可能在GUI中实施撤消操作)。但是,如果没有更多地了解大局,他们仍可能会应用不适当的模式。

相比之下,精通型程序员则能够确定何时Memento Pattern失败(例如,在你要复制大量数据,或要有大量拷贝量的时候)。他们或许会知道一些可考虑的替代方案,在模式并非完美匹配的时候。他们还对如何在Memento背后采用基本概念有一些想法,然后应用这些想法以创建一个自定义更适合特定用例的解决方案。

更为重要的是,精通型程序员能够识别正确和错误的设计模式——如果建设概念验证功能,适当代码设计的问题可能就变得无关紧要。如果向初学者解释代码库,精通型开发者可能会坚持着重于代码实际上是做什么的,而不会抛出命名模式,并告诉新手“在问我任何问题之前,先去阅读《Gang of Four》”。

所以精通还意味着有整体思维的灵活性。

模式,原则,风格,库,语言功能——这些都是工具。但是,一个真正的精通型程序员会让工具来匹配工作,而不是工作匹配工具。

许多人从来没有专门专注于发展精通能力,因为坦率地说,胜任能力更直接。但是,如果你想要改变重点并得到一些帮助来攀登一段新的历程,那么不妨试试这些:

  • --解释为什么你想要用某种方式做事的原因推理,不依赖于通用的“最佳做法”或社区准则。单单只在你要解决的当前问题的背景下讨论利弊。
  • --了解的东西越少,了解得越深。然后尝试在不同的上下文中加以应用,看看它们在哪里有效,在哪里无效。从失败中寻找机会来寻求新的工具,可以帮助拓宽你的技能集的工具,但只在你已经确立了明确要求的时候。
  • --寻找其他人“打破规则”并取得成功的范例。偶尔打破自己的一些规则,看看是会伤害你,帮助你,还是没有变化。
  • --挖掘基本的资源,而不仅仅是阅读摘要。这需要更多的时间和精力,但可以帮助你弄清楚基础和技术界限,同时也给你一个机会来生成由核心原则启发的新想法。
  • --深入钻研一个你不熟悉的项目,并且试着不依赖记忆套路、习惯和规则,找到你自己的做事方式。
  • --要求别人解释为什么他们要这样做事,但不要只是接受教条式的推理。要求例子并询问上下文背景,以便于你可以尝试着设身处地地去想。这样做是非常有价值的,因为可以让你看到他们自然习惯中的长处和短处。
  • --挑选少数特定你只是擅长但不精通的技能,然后开发胜任的能力到极致,到几乎偏执的程度。一旦你到达顶峰,检查深刻且高度专业化知识的利弊。

关于精通,一次一步,有很长的路要走。你需要超凡程度的胜任才能够在“懂和会”上脱颖而出——但即使是松散的明白“如何在正确的时间做正确的事情”也会带你走得很远。

关于精华的部分是:一旦你开始注重于精通程度,那么你有很大的机会最终会发现解决谜团的正确路径。

原文发布于微信公众号 - java一日一条(mjx_java)

原文发表时间:2016-09-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏程序员的知识天地

优秀程序员的10条黄金法则!

这是一条非常值得遵循的伟大原则。我很习惯于回过头去检查自己写下的代码,重构那些被多次使用的部分。虽然在将一个长方法分解为若干个短方法时,会遇到一些困难。Ctrl...

1114
来自专栏程序员互动联盟

怎样学习一门编程语言

1、选择一门语言 ? 2、确定你感兴趣的领域 你可以开始学习任何编程语言(尽管其中一些被描述地比其他的更加“易学”),你得去问自己自己想用通过学习这门语言完成什...

4999
来自专栏Python web开发

5本必读Python入门书籍,你都看过吗?(附福利)

今天技术学派为大家准备了5本Python入门书籍,除了书籍小编还整理了3个常用的资源网站分享给大家。

1870
来自专栏日常学python

Python 面试宝典

步入 9 月,徐徐的秋风给酷热的天气带来丝丝凉意。同时,也吹来一股招聘高潮。俗话说“金九银十”,每年的 9、10 月都是招聘高潮。有些小伙伴会参加秋招,有些小伙...

2203
来自专栏程序员互动联盟

白纸一张,如何玩转linux?

疑惑一 linux系列经典的书籍 入门篇 《LINUX权威指南》书不错,写的很全面也比较广,涉及的不深,做为入门书籍不错,可以比较全面的了解linux 。另外比...

3678
来自专栏诸葛青云的专栏

C语言单纯的模拟麻将胡牌算法!简单分析,不喜莫入

不带赖子,14张牌,以筒子为例子,不考虑杂交系列,纯属探索性算法,并非完整麻将算法,请勿存在误区。单纯的模拟题, 简单的搜索。

3440
来自专栏即时通讯技术

Dubbo正式进入Apache开源孵化器

2018年2月9日,Apache 基金会的邮件列表上发起了讨论是否接纳阿里的 Dubbo 项目进入 Apache 孵化器的投票。

1851
来自专栏机器人网

数据科学中应该学习哪些语言?来看看哪些应该掌握的?

 作者:Aceyclee   简评:原始的数据科学是劳动密集型活动,但当你会用适合的语言进行工作时,数据科学应该是非常智能有趣的工作,会让你得到一些不容易看到...

2673
来自专栏java一日一条

关于烂代码的那些事(上)

最近写了不少代码,review了不少代码,也做了不少重构,总之是对着烂代码工作了几周。为了抒发一下这几周里好几次到达崩溃边缘的情绪,我决定写一篇文章谈一谈烂代码...

1532
来自专栏Java学习网

精通型程序员的特点

你知道有能力胜任和精通之间的区别是什么吗? 这听起来像一个很难回答的问题,因为这两者似乎意味着同样的事情。但它们之间的微妙区别至关重要。 有能力胜任是指有足够的...

3246

扫码关注云+社区

领取腾讯云代金券