20 件程序员必须知道的事

我最近看了一本叫做《the 97 Things a Programmer Should Know》的书。书是一本好书。不过,下面我将我认为最值得我们了解的 20 件事情列举给大家:

1 . 应用函数式编程原则

引用透明性是一个非常可取的特性。这意味着,不论何时调用它,对于同一组参数它永远给出同样的结果,这使它跟那些与其他系统相互交织的东西比起来更易于使用。

2 . 从用户的角度看问题

你不是用户。不要把你的想法强加到用户头上,每个人的想法都不尽相同。花一个小时去观察用户的行为比你花上一天的时间去猜测他们想要什么要有用得多。

3 . 心口不一的客户。

在你决定客户需求之前,最好先和他们多讨论几次,重新确认问题。有时候,客户前后谈论的话题以及不同客户群体之间的想法是会有出入的。如果你想要成功,那么必须得在软件开发之前先好好解决差异问题。

在交流时不妨使用一些直观的辅助工具,例如白板、可视化模型等,有助于客户的理解和信息保存。

4 . 以 Why 开始

不要客户说什么就是什么,多问几个 Why。只有弄清楚需求背后的原因,才能发现新的可能。很多时候,我们可以通过对现有产品的改动来完成需求,大大减少工作量。

有时候,客户的想法与你对产品的看法可能达不成一致。那么反过来问自己“Why?”。这能让你更加明确自己的第一感觉是否对头。如果还是裁决不了,那么就需要其他主要决策者的参与。

5 . 努力并不一定都有回报

不要工作得太辛苦。减少工作量,增加工作效率,才能完成更多的工作。我可不是在忽悠你。做项目时,如果想减少工作量,那么势必得找到实现目标的高效途径。在提高了工作效率的同时还有助于积累经验。以后碰到这样的问题不就是三下五除二的事了。

6 . 大量刻意的训练

我们还可以训练自己从而提高执行任务的能力。这是一种技巧和技术,也意味着重复——意味着带着某种目的去执行任务。不断地重复 and 重复,一遍又一遍,直到你达到所需的能力级别。

译者注:我曾经学 asp 的时候重复写了几十遍数据库操作的代码,都会背了:)

7 . 做点所谓的“重复工作”

使用现有的代码与一步步设计自己的软件——测试、修复、改进——是完全不同的。这些旁人看来所谓的“重复工作”有助于你更深刻地熟悉并理解现有的各个组件是如何运作的。

大多数开发人员可能从来没有创建过核心的软件库,因此对它们的工作原理也不甚了解。其结果就是,一旦碰到这些种类的软件出现问题就会束手无策。了解表面永远是不够的,只有将里面隐含的工作原理挖出来,才能让你真正地在这一行业,独步武林。

8 . 不断学习

阅读。(译者注:订阅《快乐码农》程序员期刊)

参与邮件讨论。

获取并编写代码。

找一个导师。

了解你正在使用的框架和库。

犯了错误,需要修复 bug 或遇到问题时,弄清楚原因。

教人也是学习的一种好方法,可以教学相长。

参于用户组或本地会议。

加入或启动研究小组。

听讲座或在线观看会谈。

学习一门新的编程语言。

梳理出新的,可用于技术堆栈的想法和点子。

9 . 知道如何使用命令行工具。

由 grep 和 SED 提供的搜索和替换能力往往比 IDE 的功能更强大。

如,查找相同名称的类:

find . -name ‘*.rb’ see ’s/.*\///‘ sort uniq -c grep -v “^ *1” sort -r

10 . Unix 工具会是你的好伙伴。

Unix 工具是很简单的扩展工具。只需要谨记以下一些简单的规则即可:

程序只需要执行单一任务

读取标准输入文本行数据

显示结果为标准输出

影响工具的操作参数使用的也是命令行。

11 . 自动化,自动化,还是自动化。

掌握 shell 语言,如 bash 和 PowerShell,构建自动化系统是不可能一蹴而就的。如果需要网站交互,可以使用如 iMacros 或 Selenium 等工具。

一开始你没必要去学习所有的 bash 命令。当你需要的时候再去学也来得及。如果碰到你认为可以自动化的任务,那么尽可能地学习并使用工具来达到自动化的目的。自动化任务越早开始越好。

12 . 版本控制

给软件版本标记一个象征性的名称,以便于将来可以轻松找到所需的确切版本。也可以创建并行开发的分支:对于正在积极支持的发布版本,大多数项目有一个活跃的开发分支和一个或多个维护分支就行了。

13 . 放下鼠标,离开键盘。

碰到实在解决不了的问题时,不妨放下鼠标,离开键盘——可以听听音乐也可以出去散散步,休息会儿——让你的大脑也休息会儿。也许过一会儿你再看这个问题的时候,答案呼之欲出了呢。

14 . 错失采用多态的机会。

多态允许我们创建小型的本地化执行上下文,而不需要 if-else 模块。它可以让我们写出的代码更少更易于理解。

15 . 特定领域类型胜过原始类型

领域类型能使得代码既易于理解,又容易测试。

16 . 为必需行为测试,而不是偶发行为。

测试的一个常见缺点就是与实现细节焊死在一起,而这些细节都是偶然的,跟所要求的功能关系不大。

17 . 测试要准确、具体。

18 . API 设计的黄金法则。

只为你开发的 API 编写测试是不够的,你还需要为使用 API 的代码编写单元测试。

19 . 编写测试程序

一个优秀的测试程序可以当作开发文档来使用,因为它们已经描述了代码是如何工作的。对于每一个场景,测试程序必须做到:

1、将程序的上下文、运行起点或者必须满足的前提条件描述清楚。

2、写清楚程序是如何被调用的。

3、将程序运行的期望结果描述清楚。

当然不同的情况下这 3 个规则也会略有不同。其他程序员只要看了测试程序就可以判断软件会有哪些不同的行为,因此,每一个测试程序应该将程序的因果关系描述清楚。

20 . 采用单个二进制文件的发布规则

建立单个二进制文件可以确保发布流程中的每一个环节顺利地进行。把握每一个运行环境的详细信息,这意味着将这些信息记录到一个文件中,同时记录环境 信息的文件也需要版本控制。如果环境配置有变化,但是你又没有控制好版本的话,那么我们就很难知道系统环境哪里发生了变化。同时,这些环境配置信息必须和 代码分离,因为代码和配置的变化频率是不同的,当然变化的原因也是不一样的。

文章转载自 开源中国社区 [http://www.oschina.net]

时间: 2024-11-03 10:12:14

20 件程序员必须知道的事的相关文章

做一个优秀程序员应该知道的15件事_其它综合

1. 懂得分享.尽可能使用开源,并且当你有能力的时候,要对其有所贡献.聚全社会之智慧,胜过某些"大"公司之短视. 2. 公平竞争.尝试其他技术.框架.方法和观点.不要总以为只有你的选择才是可行的.别的选择也有可能比你的要强得多.要以开放的心态,来检验其他人的选择. 3. 不要攻击他人.像第2条所说的,不要仅仅因为别人恰巧使用.Net.Java或PHP就去攻击他们(我在这方面有一次教训).有时,它们或许要比你所认为的更有效.只要别人不是一无是处,你就可以从他们那里学到很多东西. 4. 自

JavaScript程序员应该知道的45个实用技巧

 在这篇文章中,我将分享一组JavaScript的技巧.窍门和最佳实践,这些都是JavaScript程序员应该知晓的,不管他们是使用在浏览器/引擎上,还是服务器端(SSJS--Service Side JavaScript)JavaScript解释器上 如你所知,JavaScript是世界上第一的编程语言,它是Web的语言,是移动混合应用(mobile hybrid apps)的语言(比如PhoneGap或者Appcelerator),是服务器端的语言(比如NodeJS或者Wakanda),并且

Java程序员应当知道的10个面向对象设计原则

(设计原则)底线是永远追求高内聚.低耦合的编码或设计. Apache 和 Sun的开源代码是学习Java和OOPS设计原则的良好范例.它们向我们展示了,设计原则在Java编程中是如何使用的.Java JDK 使用了一些设计原则:BorderFactory类中的工厂模式.Runtime类中的单例模式.java.io 类中的装饰器模式.顺便说一句,如果您真的对Java编码原则感兴趣,请阅读Joshua Bloch 的Effective Java,他编写过Java API.我个人最喜欢的关于面向对象设

Java程序员应该知道的10个调试技巧

调试可以帮助识别和解决应用程序缺陷,在本文中,作者将使用大家常用的的开发工具Eclipse来调试Java应用程序.但这里介绍的调试方法基本都是通用的,也适用于NetBeans IDE,我们会把重点放在运行时上面. 在开始之前,推荐大家去看看Eclipse shortcuts这篇文章,它将会给你带来很多方便.在本文中使用的是Eclipse Juno版(Eclipse 4.2),在开始前给大家提3点建议! 1.不要使用System.out.println作为调试工具 2.把所有涉及到的组件日志级别激

分享Java程序员应该知道的10个调试技巧_java

可以帮助识别和解决应用程序缺陷,在本文中,作者将使用大家常用的的开发工具Eclipse来调试Java应用程序.但这里介绍的调试方法基本都是通用的,也适用于NetBeans IDE,我们会把重点放在运行时上面. 在开始之前,推荐大家去看看Eclipse shortcuts这篇文章,它将会给你带来很多方便.在本文中使用的是Eclipse Juno版(Eclipse 4.2),在开始前给大家提3点建议! 不要使用System.out.println作为调试工具 把所有涉及到的组件日志级别激活并使用 使

程序员应该知道的 13 个设计技巧

开发你的美感- 我最喜欢的站点是: awwwards.com– 多看每日和每月上榜站点 unmatchedstyle.com – 评论很有用 dribbble.com ( Easy注:我经常去,很多NB的app设计都在上边 patterntap.com 多花些时间我在开发应用和网站时,会在设计上花掉和编码同样的时间.好的设计需要时间来完善. 在开始项目时,我一般对于整体布局有基本的想法.当我有想法的时候,我同时进行设计和编程.我会在开发细节功能的同时在浏览器里边设计那些细节.这可能不是最有效率的

JavaScript程序员应该知道的45个实用技巧_javascript技巧

如你所知,JavaScript是世界上第一的编程语言,它是Web的语言,是移动混合应用(mobile hybrid apps)的语言(比如PhoneGap或者Appcelerator),是服务器端的语言(比如NodeJS或者Wakanda),并且拥有很多其他的实现.同时它也是很多新手的启蒙语言,因为它不但可以在浏览器上显示一个简单的alert信息,而且还可以用来控制一个机器人(使用nodebot,或者nodruino).掌握JavaScript并且能够写出组织规范并性能高效的代码的开发人员,已经

前端程序员应该知道的 15 个 jQuery 小技巧

下面这些简单的小技巧能够帮助你玩转jQuery. 返回顶部按钮 预加载图像 检查图像是否加载 自动修复破坏的图像 悬停切换类 禁用输入字段 停止加载链接 切换淡入/幻灯片 简单的手风琴 让两个div高度相同 在新标签页/窗口打开外部链接 通过文本查找元素 在改变visibility时触发 AJAX调用错误处理 链式插件调用 通过使用jQuery中的animate 和scrollTop 方法,不用插件就可以创建一个滚动到顶部的简单动画: // Back to top  $('.top').clic

JAVA程序员应该知道的linux命令

常用命令 1.在compose Bar下可以对多个服务器同时进行操作.选择To All Sessions 2. 查看JAVA进程: ps -ef | grep java ps auxf | grep java 3.杀死JAVA进程: pkill java (在有反串改的时候可以用,杀死所有java进程) kill -9 进程ID ps -ef | grep "Dcatalina.base=/usr/oa/appserver" | grep -v "grep" | a