`
wgcode
  • 浏览: 576888 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

如何成为强大的程序员?

 
阅读更多

 

Aaron Stannard是新创公司MarkedUp的CEO,他最近花费大量时间雇佣、评估很多不同的程序员,并和他们一起协作。在这个过程中他发现并总结了十种程序员无法意识到自己潜力的原因,意在让更多程序员发掘出自己的潜力,从而成为强大的程序员。

 

Aaron提到,他的公司中所使用的技术非常复杂,某些大型企业都很难掌握,所以对于想要加入团队的程序员来说,入门门槛非常高。因此,尽管他们非常仔细地雇佣新人,但还是很难找到足够天才的程序员。于是,他总结出十种阻碍程序员职业生涯发展的行为,并据此来帮助想要提升自身的平凡的程序员们。

 

 

 

1. 太害怕学不会新的工具、语言和框架

一般的程序员会墨守他们最喜欢的工具,而不希望学习新的,因为他们认为,离开了那些语言和工具,多年的经验就会付诸东流。而强大的程序员会拥抱那些挑战和机会,积极地学习新的工作方式。


 

2. 直到特性“完成”的时候才会提交。(但永远都不会完成!)

他在MarkedUp公司中把这种行为叫做“囤积提交(commit hoarding)”。有些程序员没有足够的信心来承受团队中其他成员的批评和审查,因此会把自己的工作藏起来,直到“完成”状态才提交。

 

这种开发者会损害团队中其他人员的生产力,因为团队看不到他每天的成果,而且他也不会在正常开发的过程中寻求帮助,这样就会造成很多“最后一分钟”的缺陷,从而让交付延迟。而强大的程序员会知道,代码并不是他们自己,因此会把代码经常自信地呈现在其他团队成员的眼前,获得批评和建议。


 

3. 只是“知其然”会很危险

在这里Aaron举了微软最近在C# 5.0中引入的async和await关键字为例,这两个关键字会让创建和管理异步调用变得很容易,但是也会造成上下文切换、对共享资源进行多线程访问的成本,仅仅对此有基本了解的程序员会盲目地使用这些特性,把所有I/O调用都封装成C#中的Task对象,这会创建出危险的、不可预测的而且非常难以测试的代码。

 

好的开发者不仅“知其然”,而且会了解为什么这么做以及应该在什么样的条件下使用。


 

4. 分析瘫痪(Analysis paralysis)

分析瘫痪是指在程序开发初期进行系统分析,常因为太过执着于控制所有可能的变化和意外,而造成大量时间的浪费,裹足不前。这是一种很经典的问题,会影响很多一般的程序员。它通常是由过度分析造成的,但是Aaron认为其根本原因在于不敢做出坏的决定。一般的程序员会担心犯错,只想一次成功。

 

而强大的程序员不会害怕,他们会编写很烂的代码,对其进行单元测试,如果认为无法达到目的,就会在45分钟之内把它抛弃。强大的程序员会积极地限制用来研究的时间,因为他们知道那是个陷阱——看起来是有效的,但经常都无效。


 

5. 没有对工具和开发过程投入

如果你想要成为天才程序员,那么就需要投入时间提升技能和知识,而将你和普通的代码工人区分开来的是快速编写出生产级别代码的能力。你可以同时拥有好的代码和速度,但是你需要先对你用于构建的过程投入。

 

一般的程序员不会对工具、过程和环境投入,只会使用大量的时间学习新的语言特性和API如何工作,但那并不会改变什么。

 

通常,你作为程序员所能够做出的最大改进并不是专注于你所编写的代码,而是优化你编写代码的过程。


 

6. 羞于请求帮助

一般的程序员羞于或者不想让人知道自己不懂,所以他们装作什么都知道,但这样就有可能提交某种非常可怕的代码到库中。说“我不知道怎么做。”没什么错,强大的程序员知道这一点,所以当被问题难住的时候就会请求帮助。


 

7. 不知道如何让其他程序员更容易使用你的代码

在所有技术团队中,工作很重要的一部分就是人员的并行(human parallelism),也就是多个人能够同时对同一代码库工作的能力。但是对于团队来说,能够异步工作也很重要,当你不在的时候我可以修改你的代码,反之亦然。

 

一般的开发者并不这么认为,他们会开始对一项任务编写代码,认为他们会永远拥有这段代码。而强大的开发者会知道技术债务的说法,从而试图通过设计代码来对其限制,让它尽可能可维护和自解释。(推荐阅读:《用鸡讲解技术债务的形成过程》、《技术债务真正的代价》)

编写可读的代码需要程序员改变他们的看法——你的代码要比你在组织中存在的时间长。


 

8. 不知道如何阅读其他人的代码(或者不想读)

当一位一般程序员看到用他所不熟悉的语言或框架编写的代码库时,就想立刻重写,而不考虑业务价值或者推向市场的时间。而强大的程序员会接受这样的观点,重写所导致的业务成本通常是不可接受的,所以应该避免这种行为。他们会试图坐在计算机前,理解、学习然后修改现有的代码。

 

阅读代码要比编写代码还难,但是强大的程序员会投入时间来学习如何超越。


 

9. 不能从最终用户的角度编码(你考虑的范围太狭窄)

有句话说得好:作为程序员,你的工作不是解决技术问题,你之所以解决技术问题,是为了解决业务问题。

 

一般的程序员只会陷在技术问题之中,而不知道最初是为什么要解决这个问题。更严重的是,一般程序员无法从头开始创建出具有业务价值的东西。当被要求基于简单的用户设计新特性的时候,他们会死板地、照着字面对故事或者说明书做出解释,这样交付的产品用户根本无法使用。因为他们不会考虑相关的用例;不会考虑最终用户的体验;并且在做面向用户的内容时,设计都会很笨重。这导致他们无法编写业务应用,只能做产品。

 

好的程序员会从最终用户的角度来看他们的代码。我怎样才能让它更轻松地解决用户的问题呢?故事的文字内容之外有哪些方面会让这个特性给用户带来更多收益呢?


 

10. 无法判断任何编程任务的业务价值

这个问题和上一个是相关的,很多技术上很强的程序员之所以无法意识到自己的潜力,是因为他们不会停下来,从业务或者组织本身的角度去看一下他们的工作。

 

强大的程序员能够自我管理,对选择如何投入时间做出很好的业务决定,他们会问这样的问题:这是我现在应该做的最有价值的事情吗?我应该为之投入多少时间?离交付日期有两个星期,我现在能做什么,从而更容易满足那个日期呢?

 

一般的程序员不会,他们只会拿着说明书,然后盲目地实现,直到结束,不关心他们的工作和公司的业务目标有什么关系,以及对其他团队和业务组会产生什么样的影响。这样,他们就会在业务价值很低的技术任务上浪费大量开发时间。

 

Aaron在最后做出总结:如果你想要成为更好的程序员,那么就要从改变你看待代码以及编码的方式开始。你需要理解所编写的每行代码背后的业务成本;你需要从客户或者最终用户的角度来看待工作;你需要接受代码会比你在组织中存在的时间更长,所以要以其他开发者能够继承的方式来设计;最重要的,永远都不要害怕新的挑战,也不要害怕请求帮助,你无法独居一隅来提升工作效果,软件开发也是社会化的工作。

 

分享到:
评论

相关推荐

    如何成为优秀的JAVA程序员

    如何成为优秀的JAVA程序员 很好很强大

    gmate, 插件集和改进使Gedit成为强大的程序员文本编辑器.zip

    gmate, 插件集和改进使Gedit成为强大的程序员文本编辑器 GMate这里软件包包含一些gedit改进,使它的更类似于 TextMate 。 软件包包含代码 Fragment 。插件和rails相关文件的自动注册。如果你在Gmate中包含的插件有...

    卓有成效的程序员(精选版)

    这是一本写给程序员、关于如何提高生产效率的书,这意味着我可以对读者作很多假设,很多基本概念也不需要浪费很多时间去解释,因为软件开发者是极其强大的计算机用户。当然,没有技术背景的用户也应该能从本书中学到...

    C#程序员参考手册C#Programmer'sReference

    在微软为.NET Framework推出的各种语言中,综合了Visual Basic的高效性和C/C++的强大功能的C#己成为最受青睐的语言。其现代、简单、完全面向对象和类型安全的特性使它成为下一代的分布式应用程序的主流开发语言。 ...

    C#程序员参考手册.pdf

    在微软为.NET Framework推出的各种语言中,综合了Visual Basic的高效性和C/C++的强大功能的C#己成为最受青睐的语言。其现代、简单、完全面向对象和类型安全的特性使它成为下一代的分布式应用程序的主流开发语言。 ...

    C#程序员参考手册 作者: Grant Palmer

    在微软为.NET Framework推出的各种语言中,综合了Visual Basic的高效性和C/C++的强大功能的C#己成为最受青睐的语言。其现代、简单、完全面向对象和类型安全的特性使它成为下一代的分布式应用程序的主流开发语言。 ...

    10种阻碍程序员职业生涯发展的行为

    在这个过程中他发现并总结了十种程序员无法意识到自己潜力的原因,意在让更多程序员发掘出自己的潜力,从而成为强大的程序员。  AaronStannard是新创公司MarkedUp的CEO,他最近花费大量时间雇佣、评估很多不同的...

    C# 程序员参考手册

    C#综合了VB简单的可视化操作和C++的高运行效率,以其强大的操作能力、优雅的语法风格、创新的语言特性和便捷的面向组件编程的支持成为.NET开发的首选语言。C#并且C#成为ECMA与ISO标准规范。C#看似基于C++写成,但又...

    这是一个成为更好的Java程序员的系列教程.zip

    通过利用这些资源,您可以开发出功能强大的语音应用程序。Java语音项目的资源包括原生的JSAPI、开源库如CMU Sphinx和FreeTTS,商业化的服务如Google Cloud Speech-to-Text API,以及其他框架和工具。通过利用这些...

    《卓有成效的程序员》精选版

    这是一本写给程序员、关于如何提高生产效率的书,这意味着我可以对读者作很多假设,很多基本概念也不需要浪费很多时间去解释,因为软件开发者是极其强大的计算机用户。当然,没有技术背景的用户也应该能从本书中学到...

    C# 2008程序员参考手册随书源码

    C# 的2008 版本附带了.NET Framework ,该版本...作为理想的资源和参考手册,经常阅读本书可以帮助您理解C# 2008 的各种功能,正是这些功能使得C# 2008 成为比以往更为强大的编程语言。C# 2008程序员参考手册随书源码

    gmate:一套插件和改进功能,使Gedit成为强大的程序员文本编辑器

    GMate 该软件包包含一些gedit改进,使其与TextMate更加相似。... 如果您对Gmate随附的某个插件有疑问或有建议,请在填写问题 安装 的Ubuntu 添加Ubuntu on Rails PPA: sudo apt-add-repository ppa:ubuntu-on-...

    程序员助手,程序代码整理工具

    Html, XML, Asp, Php等多种语法,以及灵活的分类数据管理功能,强大的数据搜索功能,可让你从复杂冗长的数据代码中解脱出来,适用于常与代码接触的学生或程序员等,给你的工作带来非常大的方便,为你的学习增加兴趣,成为你...

    程序员学习Python的用处解析,举例说明如何用Python开发小游戏代码.docx

    该语言易于使用且具有强大的库,使其成为开发深度学习模型的理想选择。 Web开发是另一个Python非常有用的领域。Python可以帮助开发动态网站和Web应用程序。流行的Web框架,如Django和Flask,都是用Python编写的。...

    计算机专业的程序员学好MySQL数据库有什么意义?和其他数据库相比,MySQL的优点分析.docx

    MySQL具有强大的安全功能,可以确保只有授权用户才能访问数据库。此外,在数据库遇到故障时,MySQL还具有恢复功能,可以快速恢复数据。 第三,MySQL是非常灵活的。它可以根据需要进行配置和自定义,以满足特定的...

    Visual C++ 6.0.rar

    自1993年Microsoft公司推出Visual C++1.0后,随着其新版本的不断问世,Visual C++已成为专业程序员进行软件开发的首选工具。相对于新版本的VC旧版本对程序员更友好。更多的程序员喜欢使用VC++ 6.0。

    git命令实用教程

    学习Git命令的不二选择,好资源值得收藏。很好很强大,可以给很多启发,资源共享。。。

    C C++程序员查询词典(第二版)(PDG)

    在当今的世界中,要成为专业的程序员,就意味着必须熟悉这两种语言。它们是现代编程的基础。 C语言是在20世纪70年代由Dennis Ritchie发明的。它是一种中级语言。C语言将高级语言的控制结构、位操作能力以及指针...

    C#程序员参考手册(1/2)

    在微软为.NET Framework推出的各种语言中,综合了Visual Basic的高效性和C/C++的强大功能的C#已成为最受青睐的语言。其现代、简单、完全面向对象和类型安全的特性使它成为下一代的分布式应用程序的主流开发语言。 ...

    SQL必知必会

    SQL语法简洁,使用方式灵活,功能强大,已经成为当今程序员不可或缺的技能。, 本书是深受世界各地读者欢迎的SQL经典畅销书,内容丰富,文字简洁明快,针对Oracle、SQL Server、MySQL、DB2、PostgreSQL、SQLite等各种...

Global site tag (gtag.js) - Google Analytics