程序员最艰巨的任务跟编写代码没有多少关系。编码是逻辑思路的一种实践,这跟程序员日常工作中的其它任务比起来相对简单。如果你认为自己还是一个水平一般的程序员,在你真正的能进入到高手行列前,请确保你已经克服了下列晋级的障碍。

1. 解释你在干什么

解释软件开发过程是一个很困难的事情。那些非程序员职业的人也许知道很多关于编程的事情,但很显然,他们不会编程。对于他们来说,我们的生活就是在一间黑暗的屋子里趴在键盘前消耗着咖啡。

你会在你的朋友、家人和同事中遇到这样的人,他会认为编码不是一个正确的职业。

2. 形象的说出软件解决方案

根据一些简短的需求——通常是一知半解的,你需要设计出数据结构,软件架构,代码算法,通信协议,以及其它所有针对商业问题的解决方案各种组成部分。然后你需要用一种外行人听的懂的术语将它们表达出来,并需要在规定的时间里提交给客户。

很少有程序员能做好这些。

3. 评估工期

这是程序员痛苦的根源。在开发任务没有完成之前,你是绝对没有可能确定完成这个任务需要的时间。也许程序跟以前写的很相似,但环境变了,问题变了,限制条件变了。

经验会提供一定的判断力,但大部分的程序员都习惯于低估问题难度。这其中的原因是他们只考虑编码方面的因素,而忽略了这个任务清单上的其它事务。

4. 维护他人的代码

针对一个问题可能会有一万种解决方案,一万种写法。接手别人写的代码,意味着你要花无数的时间在成千上万的代码行里探索,理解当初作者的思路。而且,如果是一个不相信注释和文档的程序员留下的半个项目,麻烦就更大了。

5. 软件边界的模糊蔓延和让人吐血的奇怪功能需求

虽然敏捷开发方法给软件范围的膨胀提供了一定的预备空间,但这并没有起到任何的作用——尤其是当你遇到一些由一时兴起的怪念头产生的功能需求。你知道这样做必定会失败。你的团队知道这样做必定会失败。但客户觉得很好,而当失败不可避免的出现时,全是你的错,因为是你没有理解他们的真实意图。

6. 在缺少优化和过度优化之间找到平衡点

复杂的软件永远不会做到完美;总会有一些更好的方案。你完全可以没完没了的优化下去,这就是为什么软件项目从来都没有提前完工的。

而另一面,“这样就行了——我以后会优化它的”这种心态也是常见的。代码今天好用,但你知道明天可能会出现麻烦或不能用。当然了,你是不需要去修改它的,它将会留给下一个倒霉蛋程序员。

7. 测试你的代码

单元测试你也写了,软件也提交了测试组,但bug依旧存在……

软件是复杂的,可能包含成千上万行代码。系统中可能存在百万的各种交互和逻辑路径;你不可能完全测试它们。

类似的,软件会在不同的条件下跟不同的平台上的不同的软件交互。你不可能所有的都测到。

写出好的单元测试是一种枯燥且辛苦的工作。理想情况下,测试应该在着手开发前就已经写好——但你如何向客户解释为什么四个星期过去了仍然没有可用的软件?

单元测试并不能覆盖每个问题点。在理想的世界里,应该有一个独立的团队来写测试并积极的去发现问题。不幸的是,对大多数项目来说,这样成本太高,时间不够,于是用开发团队来写测试程序。而开发团队潜意识的会避免很多极端的边界情况。

程序员喜欢用符合逻辑的方式处理所有问题。但用户很少是这样的。他们会发现你永远意想不到的问题。

8. 写软件文档

给代码写文档是一项费力耗时的工作。很少有程序员擅长这个、喜欢这个的,并且很少有程序员会花时间去读它们。

9. 处理IT问题

你每天都在研究技术。你也许是一个HTML或PHP程序员,但你很可能会遇到一些例如硬盘损坏、驱动冲突或软件崩溃的问题。解决这些事情不是你的主要责任,但是,除非你解决了这些问题,否者你将无法继续你的开发工作。

不幸的是,对于IT圈外的人来说,程序员应该是软硬件都精通的人。当他们遇到了问题,他们自己不花时间就解决,直接会找你。不论是遇到什么问题:你是用计算机的,你一定知道如何将预算表导入Sage,如何配置Oracle,或为何在他们的黑莓手机上发不出邮件。

当然了,这些打搅绝对不能成为你完不成工作的理由,也没有报酬,不是吗?

10. 处理人的问题

上面的这些难题都可以总结为“人的问题”。很少有外行人会去建议一个飞行员如何开飞机或建议一个电器工程师如何布线。但很多人却会兴致勃勃的勇敢的建议如何开发软件。

我相信对于这些人没有什么好办法。你需要接受这样的事实:这世界上有一半的智力是低于平均水平的!

推荐一个交流学习群:650385180里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多:

程序员的10大老大难问题相关推荐

  1. 程序员的10大境界,计算科学的10层楼,比尔盖茨看了会自卑,牛顿看了会落泪!

    程序员10大境界 作者简介:周伟明先生毕业于上海交通大学,1994年开始 从事专业软件开发,曾工作于美国加州硅谷的DASCOM Inc公司(现为IBM的全资子公司)和华为技术有限公司等企业.在网络安全 ...

  2. 程序员面试 10 大潜规则,千万不要踩坑!

    作者:姿势帝 链接:www.cnblogs.com/newAndHui/p/12451882.html 潜规则1:面试的本质不是考试,而是告诉面试官你会做什么 很多刚入行的小伙伴特别容易犯的一个错误, ...

  3. 程序员的10大职业谏言

    假如你想在IT行业里当中做的比其他程序员突出,那么,下面这些现象你要多考虑,随着越来越快速的开发.开发运营和分布式版本控制系统的逐渐流行,逐渐从之前的各人开发转移到现在的团队作战. 一般情况下,团队和 ...

  4. 成为优秀Java程序员的10大技巧

    来自:http://geek.csdn.net/news/detail/114500 Java程序员有许多应遵循的守则或最佳实践方式.本文概述了每个开发者最应该遵循的10条守则或戒律,如果不遵循它们, ...

  5. 新手程序员必备10大技能

    如果你已经有一段时间的编程经验,或者正准备学习编程,那么可能会考虑的是:怎样才能成为一名优秀的程序员?计算机专业的毕业生如何为软件开发和编程职业生涯做准备?职场对于初级开发人员有哪些期望?这是临近毕业 ...

  6. 程序员常见10大口头禅

    点击上方蓝色"程序猿DD",选择"设为星标" 回复"资源"获取独家整理的学习资料! 来源 | 占小狼的博客 0.这个昨天还是正常的 1.试试 ...

  7. 程序员的10大编程技巧

    1橡皮鸭调试法 不知道各位有没有这样的经历,当你正在给别人描述问题的时候,突然灵机一动想到了解决方案? 这种情况的产生是有科学依据的.高谈阔论能让我们的大脑重新有条理地组织问题.在这种情况下,你的聊天 ...

  8. 程序员编程10大原则,请牢牢记住

    1.想清楚,再动手写代码 刚入行的新手,为了展示自己的能力,拿到需求迫不及待地就开始上手写代码,大忌! 2.不交流,就会头破血流 不爱说话和沟通,需求都理解错误了,最后做出来才发现,只能加班返工! 3 ...

  9. 程序员编程10大原则,请牢牢记住!

    全世界只有3.14 % 的人关注了 数据与算法之美 1.想清楚,再动手写代码 刚入行的新手,为了展示自己的能力,拿到需求迫不及待地就开始上手写代码,大忌! 2.不交流,就会头破血流 不爱说话和沟通,需 ...

最新文章

  1. Promise 化回调式函数
  2. 最近在北京做银行软件项目亲身感受小总结
  3. 常见笔顺错误的字_最全汉字书写笔顺规则
  4. IP地址与二进制转换
  5. 通俗理解Spring的IOC和AOP
  6. python的顶级库_世界上最顶级的python库,NumpyPandas
  7. object-fit 解决图片指定大小被压缩问题
  8. 对于Linux安装mysql5.7版本出现的问题
  9. 大数据系统架构的通用模块有哪些
  10. python定时模块:apscheduler
  11. 团队计划(4.22)
  12. 使用bootstrap建立响应式网页——头部导航栏
  13. 将软件代码从Delphi 7迁移升级到Delphi 10.4.1等现代化新版本的注意事项
  14. 1.2 架构结构和视图
  15. Windows设置眼睛保护色
  16. 计算机软考集成项目管理工程师,计算机软考系统集成项目管理工程师
  17. Android发带附件和图片的邮件
  18. mysql日期转为周数
  19. jsapi 支付缺少appid ¬ify_url
  20. [Android]判断滑动是向左还是向右?

热门文章

  1. 图学习02—图神经网络的发展
  2. html css齿轮滚动特效,CSS_纯CSS3实现滚动的齿轮动画效果,纯CSS写的齿轮效果。支持chrome - phpStudy...
  3. 「牛客网C」初学者入门训练BC156
  4. 如何將人臉變漂亮(三)
  5. 管理之黄金圈理论:让自己更值钱的5个能力
  6. eBPF/XDP实现Conntrack功能
  7. 【自己动手设计一个简单的加密算法Python】
  8. 【最受欢迎最容易理解的初阶c语言教学】4.操作符和常见关键字
  9. 浙江环宇集团“营改增”项目启动会成功举办
  10. 生成艺术or游戏?无限可能的体验#Wayfinder-探索这片土地的诗意