10+年程序员总结的20+条经验教训

时间:2024.4.30

10+年程序员总结的20+条经验教训

以下是我作为一名程序员经过10几年时间总结出的一些有关于软件开发的经验规则:

10年程序员总结的20条经验教训

开发

1.从小事做起,然后再扩展

无论是创建一个新的系统,还是添加功能到现有的系统中,我总是从一个简单到几乎没有任何所需功能的版本启动,然后再一步一步地解决问题,直到满意为止。我从来没有妄想过能够一步登天。相反,我一边开发一边学习,同时新掌握的信息还可以用于解决方案中。

我很喜欢John Gall的这句话:“复杂系统总是源于简单系统的演化。”

10年程序员总结的20条经验教训

2.一次只改变一件事

当我们在开发时,碰到测试失败和功能无效的情况,如果你一次只研究一个问题,那将会更

容易找到问题的关键。换言之,就是使用短迭代。必须确保这个问 题解决之后,再转移到另一个问题上。这适用于向下提交。如果在你添加新功能之前需要先重构代码,那么先提交重构,然后再添加新的功能。

3.尽早地添加日志记录和错误处理

在开发新系统时,我做的第一件事就是添加日志和错误处理,因为这两者从一开始就非常有用。如果系统不能照常工作,那么你就需要知道程序中发生了什么——这是日志的作用。错误处理也是如此——错误和异常越早处理越好。

4.每一行新代码必须至少执行一次

在你真正完成一个功能之前,你必须对它进行测试。不然,你怎么知道它是不是按照你的想法在执行呢?通常情况下,最好的方法是通过自动测试,但并非总是如此。不过,不管怎么说,每一行新代码必须至少执行一次。

5.在整体测试之前先进行模块测试

先进行部分模块测试可以节省时间。通常说来,我们在整合不同的模块时也会出现问题,例如模块之间的接口不匹配。但是如果我们能够信任各个组件的话,那么跟踪集成问题就会变得简单得多。

10年程序员总结的20条经验教训

6.所有事情所花费的时间总是比你预期的要长

特别是在编程中,即使一切进展顺利,我们也很难对功能所需的时间做出正确的预算。并且,开发软件时碰到各种意想不到的问题是非常常见的。

侯世达定律其实道出了真谛:做事所花费的时间总是比你预期的要长,即使你在预期中已经考虑了侯世达定律。

7.先了解现有的代码

大多数的编码都需要以某种方式改变现有的代码。即使是新功能,也需要适应现有的程序。所以,在你加进去新的内容前,首先需要了解当前的解决方案。否 则,你一不小心就很有可能会打破现有的功能。这意味着,阅读代码和编写代码都是必要的技能。这也是为什么看似微小的变化仍可能需要很长时间才能解决的原因 之一——你首先必须了解上下文。

8.阅读和运行

幸运的是,对于理解代码,我们有两种互补的方法。你可以阅读代码,也可以运行代码。运行代码的确是个非常棒的好方法。所以,请确保充分利用这两种方法。

故障排除

9.bug总是难免的

我不喜欢那些宣称软件开发可以“一蹴而就”的高谈阔论。不论你再怎么费尽心机,bug总是难免的。最好能够做成可以快速故障排除、修复bug和部署修复的系统。

10.解决故障报告

每个开发人员都应该花时间去处理来自客户的故障报告,并修复bug。这能让你更好地理解客户的意图,明白如何使用系统,知道排除故障的难易程度,了解系统的设计情况。这也是为自己的开发成果负责的好方法。

10年程序员总结的20条经验教训

11.重现问题

修复bug的第一步就是重现问题。然后你得确保修复之后,问题能够彻彻底底地消失。这样一个简单的规则可以确保你不会误将非问题当作是问题,并确保解决方案真的能够奏效。

12.修复已知错误,然后再看看有没有遗漏的地方

有时候,可能同时存在着几个不同的问题。它们之间的互相作用,可能会让你毫无头绪,束手无策。不要纠结于搞清楚发生了什么,先去解决所有已知的问题,然后再看看还有什么不对的地方。

13.没有巧合

在测试和故障排除时,不要相信会出现什么巧合。就像你改变了定时器的值,那么就会改变系统重启的频率。所以一切都并非是巧合。添加新功能,另一个不相干的功能变慢了?这绝对不是巧合。相反,是你应该仔细调查的内容。

14.关联时间戳

在故障排除时,事件的时间戳可以作为你的好帮手。寻找偶数增量。例如,如果系统重启了,并且刚刚发出过一个3000毫秒左右的请求,那么可能是触发了某个定时器,才导致出现重启的动作。

团队合作

15.面对面的交流最有效

当我们需要讨论如何解决问题时,那么面对面的交流比视频、打电话和电子邮件都要好。

10年程序员总结的20条经验教训

16.橡皮鸭法

遇到你绞尽脑汁也解决不了的问题时,不妨找一个同事,然后将问题解释给他们听。很多时候,当你在叙述时,即使你的同事一言不发,你可能也会突然灵光乍现找到问题的关键。

17.问问题

阅读和运行代码往往非常有助于指出代码的目的和它的工作原理。但是如果你有机会咨询那些更为了解的人(例如原来的程序员),那么千万不要错过。

18.共享荣誉

不要贪图荣誉,该是谁的就是谁的。例如:“Marcus想出了这个主意??”(如果真是他想的话),而不要说“我们想出的??”。

其他

19.尝试

如果你不知道某种编程语言功能的工作原理,那么不妨写一个小程序来理解它是如何工作的。这同样适用于测试你正在开发的系统。如果我将参数设置为-1,会发生什么?当我在重启系统时,如果服务当掉,会发生什么?以此来研究它的工作原理。

20.带着问题睡觉

如果你正在解决一个很难的问题,那么不妨带着问题睡觉。有科学研究表明,这样做虽然你表明上并没有在主动思考,但你的潜意思却这么做了。其结果就是,第二天再去研究问题,解决方案已经呼之欲出了。

21.跳槽

不要害怕跳槽。和不同的人共事,开发不同的产品,感受不同的公司文化是非常有意思的。

10年程序员总结的20条经验教训

22.不断学习

我们需要不断地学习和了解软件开发。你可以尝试不同的编程语言和工具,阅读软件开发的书籍,接受MOOC课程。相信我,量变才能达到质的飞跃,这些小小的学习积累,终有一天会大大地提高你的知识和能力。

希望这些经验能对大家有用。如有不当之处,敬请指正。


第二篇:慕课网分享:10+年程序员总结的20+条经验教训


10+年程序员总结的20+条经验教训

以下是我作为一名程序员经过10

慕课网分享10年程序员总结的20条经验教训

几年时间总结出的一些有关于软件开发的经验。规则:

●开发

1.从小事做起,然后再扩展

无论是创建一个新的系统,还是添加功能到现有的系统中,我总是从一个简单到几乎没有任何所需功能的版本启动,然后再一步一步地解决问题,直到满意为止。我从来没有妄想过能够一步登天。相反,我一边开发一边学习,同时新掌握的信息还可以用于解决方案中。

我很喜欢John Gall的这句话:“复杂系统总是源于简单系统的演化。”

慕课网分享10年程序员总结的20条经验教训

2.一次只改变一件事

当我们在开发时,碰到测试失败和功能无效的情况,如果你一次只研究一个问题,那将会更容易找到问题的关键。换言之,就是使用短迭代。必须确保这个问题解决之后,再转移到另一个问题上。这适用于向下提交。如果在你添加新功能之前需要先重构代码,那么先提交重构,然后再添加新的功能。

3.尽早地添加日志记录和错误处理

在开发新系统时,我做的第一件事就是添加日志和错误处理,因为这两者从一开始就非常有用。如果系统不能照常工作,那么你就需要知道程序中发生了什么——这是日志的作用。错误处理也是如此——错误和异常越早处理越好。

4.每一行新代码必须至少执行一次

在你真正完成一个功能之前,你必须对它进行测试。不然,你怎么知道它是不是按照你的想法在执行呢?通常情况下,最好的方法是通过自动测试,但并非总是如此。不过,不管怎么说,每一行新代码必须至少执行一次。

5.在整体测试之前先进行模块测试

先进行部分模块测试可以节省时间。通常说来,我们在整合不同的模块时也会出现问题,

慕课网分享10年程序员总结的20条经验教训

例如模块之间的接口不匹配。但是如果我们能够信任各个组件的话,那么跟踪集成问题就会变得简单得多。

6.所有事情所花费的时间总是比你预期的要长

特别是在编程中,即使一切进展顺利,我们也很难对功能所需的时间做出正确的预算。并且,开发软件时碰到各种意想不到的问题是非常常见的。

侯世达定律其实道出了真谛:做事所花费的时间总是比你预期的要长,即使你在预期中已经考虑了侯世达定律。

7.先了解现有的代码

大多数的编码都需要以某种方式改变现有的代码。即使是新功能,也需要适应现有的程序。所以,在你加进去新的内容前,首先需要了解当前的解决方案。否则,你一不小心就很有可能会打破现有的功能。这意味着,阅读代码和编写代码都是必要的技能。这也是为什么看似微小的变化仍可能需要很长时间才能解决的原因之一——你首先必须了解上下文。

8.阅读和运行

幸运的是,对于理解代码,我们有两种互补的方法。你可以阅读代码,也可

慕课网分享10年程序员总结的20条经验教训

以运行代码。运行代码的确是个非常棒的好方法。所以,请确保充分利用这两种方法。

●故障排除

9.bug总是难免的

我不喜欢那些宣称软件开发可以“一蹴而就”的高谈阔论。不论你再怎么费尽心机,bug总是难免的。最好能够做成可以快速故障排除、修复bug和部署修复的系统。

10.解决故障报告

每个开发人员都应该花时间去处理来自客户的故障报告,并修复bug。这能让你更好地理解客户的意图,明白如何使用系统,知道排除故障的难易程度,了解系统的设计情况。这也是为自己的开发成果负责的好方法。

11.重现问题

修复bug的第一步就是重现问题。然后你得确保修复之后,问题能够彻彻底底地消失。这样一个简单的规则可以确保你不会误将非问题当作是问题,并确保解决方案真的能够奏效。

12.修复已知错误,然后再看看有没有遗漏的地方

有时候,可能同时存在着几个不同的问题。它们之间的互相作用,可能会让你毫无头绪,束手无策。不要纠结于搞清楚发生了什么,先去解决所有已知的问题,然后再看看还有什么不对的地方。

13.没有巧合

在测试和故障排除时,不要相信会出现什么巧合。就像你改变了定时器的值,那么就会改变系统重启的频率。所以一切都并非是巧合。添加新功能,另一个不相干的功能变慢了?这绝对不是巧合。相反,是你应该仔细调查的内容。

14.关联时间戳

在故障排除时,事件的时间戳可以作为你的好帮手。寻找偶数增量。例如,如果系统重启了,并且刚刚发出过一个3000毫秒左右的请求,那么可能是触发了某个定时器,才导致出现重启的动作。

●团队合作

15.面对面的交流最有效

当我们需要讨论如何解决问题时,那么面对面的交流比视频、打电话和电子邮件都要好。

慕课网分享10年程序员总结的20条经验教训

16.橡皮鸭法

遇到你绞尽脑汁也解决不了的问题时,不妨找一个同事,然后将问题解释给他们听。很多时候,当你在叙述时,即使你的同事一言不发,你可能也会突然灵光乍现找到问题的关键。

17.问问题

阅读和运行代码往往非常有助于指出代码的目的和它的工作原理。但是如果你有机会咨询那些更为了解的人(例如原来的程序员),那么千万不要错过。

18.共享荣誉

不要贪图荣誉,该是谁的就是谁的。例如:“Marcus想出了这个主意……”(如果真是他想的话),而不要说“我们想出的……”。

●其他

19.尝试

如果你不知道某种编程语言功能的工作原理,那么不妨写一个小程序来理解它是如何工作的。这同样适用于测试你正在开发的系统。如果我将参数设置为-1,会发生什么?当我在重启系统时,如果服务当掉,会发生什么?以此来研究它的工作原理。

20.带着问题睡觉

如果你正在解决一个很难的问题,那么不妨带着问题睡觉。有科学研究表明,这样做虽然你表明上并没有在主动思考,但你的潜意思却这么做了。其结果就是,

慕课网分享10年程序员总结的20条经验教训

第二天再去研究问题,解决方案已经呼之欲出了。

21.跳槽

不要害怕跳槽。和不同的人共事,开发不同的产品,感受不同的公司文化是非常有意思的。

22.不断学习

我们需要不断地学习和了解软件开发。你可以尝试不同的编程语言和工具,阅读软件开发的书籍,接受MOOC课程。相信我,量变才能达到质的飞跃,这些小小的学习积累,终有一天会大大地提高你的知识和能力。

希望这些经验能对大家有用。如有不当之处,敬请指正。

慕课网()分享,希望对你们有所帮助。

更多相关推荐:
工作经验及教训总结报告

从参加工作到现在已经经历了四个春秋,从当初的那个充满干劲的菜鸟慢慢变成如今浑浑噩噩的老油条,这期间有激情、快乐、挫折、彷徨、消沉、麻木。不知道是不是环境改变了我还是我抵挡不住岁月的侵蚀,感觉自己的心在慢慢老去。…

项目经验教训总结模板

XXX产品开发项目经验教训总结仅供内部使用编制审核会签批准修订记录版权所有侵权必究第2页共12页目录12前言6团队的管理621跨部门团队621121221322做得好的地方6做得不足的地方6优先的改进建议6和I...

总结经验教训

总结经验教训应对更严峻的安全管理工作通过学习群众路线教育实践活动结合安全工作实际情况回顾半年来的安全工作总结起来分析起来我们感到自己肩上的担子很重一安全状况20xx年17月份全矿共发生各类事故24起其中死亡事故...

总结经验 吸取教训

合理谋划确保年度目标实现——20xx年工作总结及20xx年工作计划各位领导、各位同事:大家好!在紧张忙碌中20xx年即将过去,在过去充实的一年中心里感触颇多,借此机会向各位领导及同仁汇报一下项目部20xx年工程…

026_项目经验教训总结报告

BGIIMR18018XX项目YY版本项目经验教训总结报告编写批准日期日期深圳华大基因研究院信息生产中心华大信息生产中心软件研发项目经验教训总结报告修改记录华大信息生产中心软件研发项目经验教训总结报告一项目经验...

123项目经验教训总结模板

项目经验教训总结机密1目录12前言5团队的管理521跨部门团队5211做得好的地方5212做得差的地方5213优先的改进建议522功能部门的支持5221做得好的地方5222做得差的地方6223优先的改进建议62...

组织培训心得及经验教训

通过入司一个多月来组织培训后体会到以下几点:培训计划做好后可不能撒手不管,不要以为一切会按计划行事,身为人力资源的我们要时刻提醒自己,培训计划推动执行的第一责任人是我们自己。因此,在正式开展培训前,我们可要提前…

开车经验教训总结

安全驾驶生存经验总结血的教训1我很庆幸刚刚开车就读到这本书有很多人是缠着绷带打着石膏躺在医院的病床上带着满腹悔恨开始读这本书的2汽车不是玩具驾驶不是刺激驾驶意味着承担责任义务和风险3人活着不能只靠运气还需要具有...

科目三必过经验教训个人总结攻略

科目三笔记一考试项目一上车准备1从车右边前面逆时针绕到左边2关好车门若未关严则不通过打开车门上车前必须观察后方交通情况确认安全后再上车否则不合格3调整好座位后视镜车身占三分之一系好安全带观察仪表4起火前左右摆动...

画楼梯经验教训总结

画14楼1号和2号楼梯总结12首先看懂建筑图的每一个细节注意是每一个细节包括平面和里面的尽量尽量不要在建筑图上加梯梁或者梯柱如果一定要布置一定仔细查看建筑平面图和立面图该位置是否可以布置梯梁以及该梯梁如何往下传...

长沙麓谷分考场科目三必过攻略个人经验教训总结

长沙麓谷分考场科目三笔记一考试项目一上车准备1从车右边前面逆时针绕到左边2关好车门若未关严则不通过打开车门上车前必须观察后方交通情况确认安全后再上车否则不合格3调整好座位后视镜车身占三分之一系好安全带观察仪表4...

【警世恒言】来自于一线的500医生的经验教训总结【上】

1首发症状表现为头面部或胸腰际部疼痛的带状疱疹见到疱疹你才恍然大悟还不要忘记疱疹病毒性脑炎壮年男性来时以手抚面呻吟不止未开口俺想是三叉神经痛吧左颞下颌关节及左耳后咽部左胸锁乳突肌上端痛二天呈持续性特别是左颞下颌...

经验教训总结范文(13篇)