阅读更多

154顶
6踩

编程语言

原创新闻 风雨20年:我所积累的20条编程经验

2010-11-15 07:55 by 见习编辑 jobbole 评论(90) 有39041人浏览

        编者按:原文作者乔纳森·丹尼可(Jonathan Danylko)是一位自由职业的web架构师和程序员,编程经验已超过20年,涉足领域有电子商务、生物技术、房地产、医疗、保险和公用事业。正如乔纳 森在文中所言,本文适合刚毕业的大学生和刚入门的程序员。如果你已是高级开发人员,或许你在本文中看到自己的身影。



  


  从11岁时,我就一直在编程,并且一直都很喜欢技术和编程。这些年来,我积累了一些艰难又容易的经验。作为一名程序员,你或许还没这些经验,但我会把它们献给那些想从中学到更多的朋友。

  我会持续更新这些经验,我可能还会有更多的感想,但就我这20年来看,我想下面这个列表中基本不需要增添额外的东西了。下面就是我至今最难忘的经验。

  1. 估算解决问题所需要的时间。不要怕,承认吧!我曾见过一些程序员为了解决一个特殊问题而坐在显示器前面8小时。为自己定一个时间限制吧,1小时、30分钟或甚至15分钟。如果在这期间你不能解决问题,那就去寻求帮助,或到网上找答案,而不是尝试去做“超级堆码员”。

  2. 编程语言是一种语言,只是一种语言。随着时光推移,只要你理解了一种语言的原理,你会发现各种语言之间的相似之处 。你所选择的语言,你应该觉得“舒服”,并且能够写出有效(而且简洁)的代码。最重要的,让语言去适应项目,反之亦然。

  3. 不要过于注重程序的“设计模式”。 有时候,写一个简单的算法,要比引入某种模式更容易。在多数情况下,程序代码应是简单易懂,甚至清洁工也能看懂。

  4. 经常备份代码。在我年轻时,我就有过因硬盘故障而丢了大量代码的经历,这经历很恐怖的。只要你一次没有备份,就应当像有着严格的期限,客户明天就需要。此时就该源码/版本控制软件大显身手了。

  5. 承认自己并不是最顶尖的程序员 - 知不足。我常想,我对编程了解已足够多,但是总有其他人比你优秀。正所谓,“一山总比一山高”。所以,向他们看齐吧!

  6、学习再学习。正如第5点所说,我经常会在手里拿一本计算机或编程相关的杂志或书(不信,可以问我的朋友)。诚然,总有很多你不知道的技术,你可以从中学习以保持不落后。如果你有一种灵巧的方式来获取你需要的新技术,那你每天都应该坚持学习。

  7. 永恒的变化你 对待技术/编程知识,就应像你对待股票一样:多样化。不要在某一特定技 术上自我感觉良好。如果那种技术或语言已经没有足够支持,那你还不如现在就开始更新你的简历,并启动培训新计划。我能保持前行的主要原则是什么呢?至少了 解两到三种语言,所以,如果某种语言过时了,你在学习新技术的时候还可以依靠另一种语言。

  8. 提携新人。协助并且培养初级/入门的开发人员学习优秀的编程方法和技巧。也许你还不知道,在帮助他们向更高一层前进时,你自己也在向更高一层提升,你会更加自信。

  9. 简化算法。代码如恶魔,在你完成编码后,应回头并且优化它。从长远来看,这里或那里一些的改进,会让后来的支持人员更加轻松。

  10. 编写文档。无 论是Web服务的API,还是一个简单的类,你尽量编写相应文档。我曾经引以为豪的代码注释,因过度 注释而有人指责。给三行代码加一行注释,只需要你几秒时间。如果那是一个比较难以理解的技术,千万别担心过多注释。如果你能很好做好自己的工作,大多数架 构师、后备程序员、支持组都会感激你。

  11. 测试、测试再测试。我是一名黑盒测试粉丝。当你完成编码后,你“被认可”的时候就开始了。如果你们公司有QA部门,如果你的代码中有错误,那你得到的评论,会比项目经理还多。如果你不彻底测试自己的代码,那恐怕你开发的就不只是代码,可能还会声名狼藉。

  12. 庆祝每一次成功。我见过很多程序员在解决编程技术难题后,会和同伴握手、击掌或甚至手舞足蹈。每个人在生命中都会碰到“顿悟”。如果一个程序员高兴地跑来叫你去看他的非凡代码,也许你已经看过这样的代码100遍了,但你也应该为了这个家伙而庆祝第101次。(编者注:《庆祝成功的九种方式》。)

  13. 经常检查代码。 在公司,你的代码要经常检查(包括自查和其他同事检查)。不要把别人的检查,看成是对代码风格的苛求。应该把它们看作是有建设性的批评。对个人来说,经常检查你的代码并且自问,“我怎样才能写得更好呢?” 这会让你加速你的成长,让你成为一个更优秀的程序员。

  14. 回顾你的代码。在 看到自己以前的代码时,通常会有两种方式:“难以至信,这代码是我写的”和“难以至信,这代码是 我写的”。第一种往往是厌恶的语气,并在想如何改进它。你也许会惊叹,旧代码也能复活成为一种更好的程序,甚至是一个完整的产品。第二种通常带着惊奇和成 就感。开发人员应该一到两个自己完成的项目成果,能让众人不禁而立并注目而观的项目。同样,基于你优越的编程能力,你可以把过去的程序或项目拿出来,把它 们更新为更加优秀的产品或想法。

  15. 幽默是不可缺的。在我20年的开发生涯中,我还没有碰到哪位程序员是没有幽默感的。实际上,干我们这行,幽默是一项必备品。

  16. 谨防那些无所不知的程序员,不愿分享的程序员,还有经验不足的程序员。当你遇到这几种程序员时,你自己要谦虚。无所不知的程序员,更想当一个英雄而不是团队成员;保守的程序员则是在编写着他们独享的代码;而经验不足的程序员则会每十分钟就来问你一下,当代码完成后,代码已经是你的,而不是他们。

  17. 任何项目都不会那么简单。朋 友、家人和同事曾请求我仓促做一些事情,仓促做一个程序或者网站。对于这样的事,应该 从双方做计划,才能做出令两方都会满意的东西。如果某人起初只是需要一个使用Microsoft Access的、只有有3个页面的网站,但来就很可能变成一个有15个页面的网站,并使用SQL Server,有一个论坛,还有一个定制的CMS(内容管理系统)。

  18. 任何时候不要想当然。假如你承接一个简单的项目,你可能会认为某个部分可以轻松完成。千万别这样想!除非你有一个类、组件、或者一段已经写好的代码,并且在现有的项目已经测试通过。不要认为这将是很容易的。

  19. 没有已经完成的软件。曾经有一位程序员告诉我,没有软件是已经完成的,它只是“暂时完成了”。这是明智的忠告。如果客户还在使用你写的程序,并经受了时间的考验。如果有机会,你仍在更新它,这并不是什么坏事,这让你不断地前行。

  20. 耐心是一种美德。当 客户、朋友或家庭成员用电脑的时候,他们也许会受挫,进而想砸电脑,或气冲冲地离开。我一直在 告诉他们,“是你掌控电脑,不是电脑掌控你。”对于用作编程的电脑,你要有一定的耐心。一旦程序员知道问题所在后,他们就会站在电脑的角度看问题,并且说 “哦,这就是为什么它是这样做。”

  编者后话

  对本文深有感触!虽然本文没有华丽的辞藻,其中朴实的道理,其实并非只适用程序员,同样可以扩展到其他行业。记得以前练字时,总感觉当时写得很好,但后来回头再看时,也会想“这居然是我写的字!”

  在阅读本文的朋友,不知你是否也有看到了自己的身影呢?欢迎你在微博或评论中和大家一起分享感触。




  本文出处:伯乐在线 - 职场博客
  本文链接:http://www.jobbole.com/entry.php/322

  Via:Jonathan Danylko 编译:伯乐在线 敏捷翻译组 - @关关

  如需转载,但请注明文章来源和超链接等版权信息,谢谢合作!

  • 大小: 12.5 KB
来自: www.jobbole.com
154
6
评论 共 90 条 请登录后发表评论
30 楼 yangjuanjava 2010-11-15 17:30
值得我们晚辈反思的东东!
29 楼 hscartoon 2010-11-15 16:59
第一次看《大话西游》,笑的乐不可支,认为是喜剧片,说明根本没看懂。
第二次看《大话西游》,哭的稀里哗啦,认为是悲剧片,说明才刚刚入门。
第三次看《大话西游》,不知道该哭还是该笑,认为是喜剧手法拍摄的悲剧片,才算真正看懂了。

28 楼 lizhengjun 2010-11-15 16:40
8、提携新人。

教学相长,的确如此。
27 楼 fxbird 2010-11-15 16:23
jlwuc 写道
有一句话:
开始,看山是山,看水是水。
然后,看山不是山,看水不是水。
最后,看山还是山,看水还是水。

确实,当你解决一个难题的时候,回头在理清时,想想其实也就那样!


这不是一位开悟的和尚的名言吗?我现在是第二阶段.
26 楼 wdq 2010-11-15 15:23
把别人的检
jlwuc 写道
有一句话:
开始,看山是山,看水是水。
然后,看山不是山,看水不是水。
最后,看山还是山,看水还是水。

确实,当你解决一个难题的时候,回头在理清时,想想其实也就那样!


这就是编程三境界啊!!!!
25 楼 jhyimu2005 2010-11-15 13:16
很值得一看!
24 楼 jlwuc 2010-11-15 12:44
有一句话:
开始,看山是山,看水是水。
然后,看山不是山,看水不是水。
最后,看山还是山,看水还是水。

确实,当你解决一个难题的时候,回头在理清时,想想其实也就那样!
23 楼 shiyangxt 2010-11-15 12:36
这些经验都有过体会,虽然还没有编多久。看来有些东西是恒久不变的。
22 楼 eclipse-my 2010-11-15 12:13
thanks, very good!
21 楼 zhang263yy 2010-11-15 12:01
路过!
20 楼 tdqing 2010-11-15 11:37
很有针对性
1、4、11、14条觉得很有准确有力
19 楼 lwp2000 2010-11-15 11:20
留个印记!
18 楼 1927105 2010-11-15 11:17
写得不错,荐一个啊
17 楼 xiaoyangok 2010-11-15 11:16
很好!!!!!!!!!!!!!!!
16 楼 zhou363667565 2010-11-15 10:46
非常好..
15 楼 zhou363667565 2010-11-15 10:46
很的很不错,受教了..
14 楼 java318 2010-11-15 10:44
好文章顶,shoucangle:D
13 楼 xijieqjx 2010-11-15 10:24
绝对顶
。。
12 楼 zuzong 2010-11-15 10:13
11 楼 kenshinlk 2010-11-15 10:11
+1

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • delphi通配符查找函数(单元)的实例

    网上只看到有通配符查找,返回boolean值的,为进行补充,单独写了一个通配符查找单元MatchFind,主要的为MatchFindStr(MainStr,SubStr)函数,返回符合条件的通配符的字符。 奇怪的是在winxp下,微软的查找中文使用通配符正确,使用英文通配符查找反而错误,诡异。本函数没这问题,对不符合规范的通配符进行过预处理。 例如:母串“数据手册_WDT-1200E_20120709.docx”,查找通配符子串“W???12*09”,返回值为“WDT-1209”。 子串“WD*”,返回值为“WDT-1200E_20120709.docx”。

  • 因为效率的问题,写Delphi下的求子串的KMP&BM算法,为我的程序提速不少

    {ImplementationofKMP&BMAlgorithmInDelphi7} unitUnit1; interface uses Windows,Messages,SysUtils,Variants,Classes,Graphics,Controls,Forms, Dialogs,StdCtrls; type...

  • KMP、BM、Sunday、Horspool、strstr字符串匹配算法的性能比较

    KMP、BM、Sunday、Horspool、strstr字符串匹配算法的性能比较 一、简介 简介:字符串匹配算法,顾名思义,在一个给定的字符文本内搜寻出自己想要找的一个字符串,平常所用的各种文本编辑器里的ctrl+F大多就是使用的这些字符匹配算法。本文通过用c语言实现4种比较受欢迎的字符匹配算法,在同一文本下搜寻同一关键字符串,用来和c库函数strstr作时间上的性能比较,同时也对实现的4种...

  • 字符串的匹配 KMP算法分析

    图片来源于  土豆洋芋山药蛋 https://blog.csdn.net/qq_33414271/article/details/83789478 1.什么是KMP算法? 在主串Str中查找模式串Pattern的方法中,有一种方式叫KMP算法 KMP算法是在模式串字符与主串字符匹配失配时,利用已经匹配的模式串字符子集的最大块对称性,让模式串尽量后移的算法。 2. 暴力匹配算法 假设现...

  • DELPHI的通配符比较 (转)

    DELPHI的通配符比较 (转)[@more@] Delphi的通配符比较 作者:李均宇 eMail: .NET">e271828@163.net或者sqlserver2000@163.com">MSSQL...

  • Delphi中TStringList Indexof如何实现区分大小写,通配符模糊匹配及字符串比较区分大小写测试

    大家都知道Delphi中一直以来都是不区分大小写的。但是如果有一天,你用TStringlist维护了一个id列表什么的。并且要实现区分大小写。实现IndexOf模糊匹配要如何实现?

  • DELPHI的通配符比较

                               DELPHI的通配符比较                                作者:李均宇  email:     e271828@163.net或者MSSQLserver2000@163.com或者OKMYdelphi@163.net     DELPHI的功能比VB强是公认的,但在一些小事小节上却有时比不上VB方便,例如VB中有S

  • 基本算法(用 PASCAL 描述)

    基本算法(用 PASCAL 描述)基本算法(用 PASCAL 描述)1.数论算法 求两数的最大公约数 function gcd(a,b:integer):integer; begin if b=0 then gcd:=a else gcd:=gcd (b,a mod B); end; 求两数的最小公倍数 function lcm(a,

  • delphi的 PosEx 函数功能介绍

    首先要引用StrUtils单元,即uses部分要加入StrUtils 函数的功能是返回子串 SubStr 在字符串 S 中的索引。可以指定查找起始位置Offset,默认从头开始查找,即Offset=1。 如果没有找到,返回0。如果指定的起始位置超过了字符串S的长度,或起始位置小于 1 ,也返回0。 StrUtils.PosEx Function Returns th

  • 终于弄懂KMP算法了

    1.简例弄懂KMP-点此链接查看 看了上面的文章,你肯定大概明白了KMP的运作原理,但是你可能对于文章提到的“部分匹配值”的又来还存在疑惑,那么请继续往下看: 我们先抛出两个问题,当目标字符串i指针与模式字符串j指针失配时: 1、当母串和模式串不匹配时,i指针为什么不需要回溯? 2、当母串和模式串不匹配时,i指针不回溯,那么j指针应该移动到哪? 通过解释第...

  • KMP算法真的搞死人,终于搞懂了

    现总结如下: 想理解KMP算法就要先看看最原始的模式匹配int match(char *string, char *pat)  //原模式匹配函数...{    int i = 0, j = 0;    while (i  strlen(string) && j  strlen(pat))  ...{        if (sting[i] == pat[j]) ...{         

  • KMP-字符串快速匹配算法

    之前一直保持在word文档中记录总结,最近发现C博客是个分享的好地方,记录自己学习总结的同时,也可以把总结拿出来分享,万一能帮到别人呢^_^ 花了两天,把KMP算法搞懂了,此篇旨在用通俗易懂的语言讲算法实现过程,但看此篇之前最好对朴素字符串匹配动手写过代码。好了,下面进入正题。 朴素字符串匹配算法时间复杂度为O(n*m),n/m分别为主串/子串长度,而KMP算法的时间

  • 我的公共函数单元(Delphi)

     

  • Delphi 利用自带类TRegEx实现正则匹配

    var matchs: TMatchCollection; const encryp_RexStr = 'encryptAccountId(.*?)isGold'; matchs := TRegEx.Matches(sResponseHtml, encryp_RexStr); if matchs.Count = 1 then begin tmpShopInfo.encryptAccountId := matchs.Item[0].Groups[1].Value; ... .

  • 为delphi补充函数!

    下面的代码是如何将10进制的数字转为 n 进制的数字。 unit BaseFunctions; interface uses SysUtils; function Dec_To_Base(nBase, nDec_Value, Lead_Zeros:integer; cOmit:string):string; // 10 进制 -> n 进制 function Base_To_Dec

Global site tag (gtag.js) - Google Analytics