开发者们需要自问的10个问题
编辑时间:2020-07-08 作者:
开发者们需要自问的10个问题

你想成为一个开发者 / 工程师吗?

那是时候放下《24 小时学会超级骗子语言》之类的书了。相反地

,每天问自己一下 10 个问题,并养成一个习惯吧。

是否有某种模式?

探寻可行与不可行中的模式,能发现背后的原理,这些原理则驱动着看似无关的概念和行为。要想对你做的工作有更深的理解,养成问自己「是否有种模式存在?」的习惯吧。

这不仅仅适用于你的程式。在各类商业需求的变化中有某种模式吗?技术进步的方式中有某种模式吗?你看到同样的错误反覆出现吗?

我该如何使它变得更简约?

通常作为 web 开发者,我们想提出複杂且可扩展的解决方案。做一些极其複杂的东西,会让你觉得自己就是宇宙的主宰。而问题是你永远不能预测到产品和业务今后会怎样变化。

「架构
」和编写程式更像是园艺而不是建筑。你需要有能力去适应不断变化的环境,解决方案越複杂,越难以适应。

为什幺它是那样运作的?

知道事情运作和知道它运作的原因,这是两件完全不同的事。如果你知道事情为什幺是那样,那幺你就能够做出更好的决策。

一个优秀的工程师和懂一点程式语言的人,差别在于理解缘由的深度。

同样的原则也适用于修复某个问题。「只需重启一下服务。」「你试过重启吗?」当问题发生时,我们经常会想到这些话。每次你这样说时,你就失去了一个绝好的学习机会。

理解问题的原因,能让你解决根本原因,并且永久消除这类错误。最起码,你将不再犯同样的错误。

之前有人做过吗?

无论何时,如果你发现自己正在发明一个複杂的演算法,你很可能就是方法不对。除非你正忙于研究博士论文,一般已经有人解决了这个问题。

需要编写一个给离使用者鼠标最近的 item 添加标籤的算法?看看 Voronoi Tesselations。想要找到卡车送货的最短路径?看看 Dijkstra 算法吧。想要找到使用者输入内容的近似标记?试试计算它的 Levenschtein 距离吧。

这些只是几个简单示例,但相信我,还有很多很多。

谁最先提到它?

你以为你知道 REST 吗?

你有读过 Roy Fielding 描述 REST 的论文原文吗?你真的明白它的用意吗?那种比你多 5 分钟经验的家伙,在 IDE v7 工具中用 REST API 生成嚮导写出来的部落格,可不算数的。

帮自己一个忙,尽可能试着去读某种概念或理论的原始文件吧,然后通过各种手段去了解行业领袖的最新发展动态。如果你不知道他们是从哪开始的,你怎幺跟得上他们的步伐呢?

我热爱现在所做的吗?

程式不简单,让我们承认吧。

除了难以外,程式还总在不断发展。最先进的框架从 2 年前的 “笨重恐龙” 已经发展到今天的标準。想要一直站在你的 “游戏” 顶端,你需要树立终生学习和研究的观念。

如果你不热爱你所做的,那幺你就没有跟上其他家伙的希望。所以找到那种让你激情燃烧的

程式类型吧!不要因为市场缺口或者收入不菲而决定成为一名安全专家,不要因为一篇文章说使用者体验是最热门的科技工作而决定成为一名使用者体验专家。

再说一次,做你热爱的。

我还可以在哪些其他的地方用到这个?

我看到 Web 开发者给他们自己设定的最大的一个限制就是,想像力的失败。

如果我们学习一个特定环境下的东西,或者看到解决某个特定问题的技术时,我们认为这就它唯一适用的地方。这种观点大多时候都是错的。每次学到新东西时,反问自己:「我还可以在哪些其他的地方用到这个?」

发现了在图表上定位节点的新的好方法?将同样的技术应用于发现 2D 数据集中有趣的数据点?找到了通过 websockets 从客户端发送数据到服务器端的新方法?它怎样才能应用到可扩展的后台服务上呢?有时你会是错误的,但有时你将是正确的。

这给我们带来了下一个问题……

今天我做错了什幺吗?

提高创新的最简单方法之一就是降低失误的成本。

游戏开发公司 Valve 和其他几个公司很赞同这个观点。这些也同样适用于你成为 Web 开发者的成长过程。如果你害怕失败,你就不会有大的突破。

勇敢点、去尝试、失败了、去学习,然后再来试试。

我们怎样使它成为可能?

现实中,一切皆有可能,而凡事均有例外。

先开始假设不管你做什幺事情都是可行的,然后回推过去来工作。你可能会发现,你想做的暂时是不切实际的,但以当今世界的变化速度,它变得可行的时间,可能比你想的要早。

我可以向谁学习?

永远不要在你是最聪明的地方工作。

挑选拥有可以启发你、激励你做得更好的同事的工作和公司。没必要和程式有关係,在文本编辑器和命令行之外还有一个世界。从其他领域学习,并应用到你的工作中。

不管怎幺样,保持竞争力更好!

欢迎加入「Inside」Line 官方帐号,关注最新创业、科技、网路、工作讯息
开发者们需要自问的10个问题
上一篇: 下一篇: