程序员难以攻克的十大难题

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

1. 解释你在干什么

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

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

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

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

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

3. 评估工期

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

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

4. 维护他人的代码

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

5. 软件范围的模糊界定和让人吐血的奇怪功能需求

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

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

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

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

7. 测试自己的代码

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

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

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

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

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

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

8. 写软件文档

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

9. 处理IT问题

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

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

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

10. 处理人的问题

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

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

来自:http://codebay.cn/post/7974.html

原文发布于微信公众号 - Spark学习技巧(bigdatatip)

原文发表时间:2018-06-16

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏DevOps时代的专栏

腾讯织云:DevOps流水线应用平台践行之路

持续交付是DevOps的核心工程实践,持续交付流水线驱动着DevOps的落地,昨天在云+峰会的开发者专场,腾讯跟大家揭开了DevOps流水线平台的神秘面纱。同时...

3609
来自专栏腾讯大讲堂的专栏

浅谈用户体验的可视化

记得初学设计时就常常听到这么句话,设计不单单是做出一个极具美感的躯壳,更重要的是它背后的实用价值——所谓设计的实用性。而在互联网里,这种实用性更多的体现在用户体...

1976
来自专栏云计算D1net

想开发云应用程序?先选择合适的PaaS!

从一个方面来分析,开发云应用程序的平台即服务模式有两种:一种是专用模式,托管在本地或私有云中;另一种是公共模式,由第三方提供商来托管,并采用订阅支付模式。那只是...

4276
来自专栏数据猿

普元信息政务大数据咨询顾问夏佳斌:数据资源体系的核心——资源定义、运营机制和支撑平台

12月1日下午,由上海大数据联盟、数据猿主办的第20期魔方大数据在上海宝华万豪酒店成功举办。本期魔方大数据以“政务大数据”为主题,邀请了技术方和产业方大咖共聚一...

33611
来自专栏腾讯云技术沙龙

大咖说:如何借助腾讯云简单、高效移动开发

一直以来,如何能够更快速地构建高性能,高扩展的移动应用一直是移动行业的热点。在传统模式下,开发者通过手动集成所需的各种移动服务,和后台紧密配合去打造精品移动应用...

95116
来自专栏SDNLAB

混合云的杀手级应用:数据保护

对于企业来说,数据保护是将大量数据存储在云端的关键原因。最终所有数据都需要备份和归档,很多IT组织将云计算视为本地存储的最具成本效益的替代方案。 ? 这一策略的...

39011
来自专栏张俊红

运营--获取用户的八大方法

今天分享的是《增长黑客》这本书,全书主要分获取用户、活跃用户、留存用户、增加收入、病毒传播五个部分,是一个产品完整的生命周期所包含的过程。本篇主要写用户获取。 ...

3278
来自专栏Java架构

阿里十年架构师分享如何成为一个Java架构师(文末附学习路线)架构的定义软件架构的重要性什么是好的软件架构什么是坏架构要知道最时尚并不一定是最好的成功的软件又是怎么样的呢JAVA通用领域的相关技术架构

3565
来自专栏程序你好

DevSecOps的三种解读

1211
来自专栏麦应用专栏

麦应用小程序 | App可直接打开小程序!微信到底想要干嘛?

未来,用户可以从APP跳转至某一微信小程序的指定页面,完成服务以后再跳转回原APP,多场景使用更加方便。

72014

扫码关注云+社区

领取腾讯云代金券