阅读更多

4顶
1踩

非技术

转载新闻 20件程序员必须知道的事

2015-02-28 15:06 by 副主编 mengyidan1988 评论(0) 有5093人浏览
我最近看了一本叫做《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. 采用单个二进制文件的发布规则

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

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 优秀程序员必须知道的20个位运算技巧

    掌握简单的位运算技巧还是必要的,所以今天写这篇文章把我积累的一些位运算技巧分享给大家,这些技巧不会是如求“1的数目”的技巧,是最基本的一行位运算技巧

  • 程序员应该知道的97件事

    程序员应该知道的97件事 ISBN: 9787121117565 作者:Kevlin Henney 译者:李军 译 / 吕骏 审校 推荐指数: ★★★★★ 阅读时间: 2016-04-24 上星期拿了三本书来看,其中一本就是《程序员应该知道的97件事》。 大概...

  • 程序员所要知道的事

    作为一个好的程序员需要注意一些细节,如 ● 理解程序员20%的时间用于编码,80%的时间用于维护,根据这一点相应安排时间。

  • 程序员应该知道的二十三种设计模式

    程序员应该知道的二十三种设计模式 适合中高级程序员

  • 惹恼程序员的十件事

    惹恼程序员的十件事  2009年04月06日 陈皓 评论 44 条评论 24,669 人阅读 程序员应该是一个比较特殊的群体,他们因为长期和电脑打交道所养成的性格和脾气也是比较相近的。当然,既然是人,当然是会有性格...

  • 刚入门的程序员朋友需要知道的30件事

    程序员不是一个容易的职业,每年都有许多人从国内顶尖院校的计算机科学专业毕业,这是任何人都能从事的竞争最大的职业之一。同时,编程也是令人兴奋的。随着技术的进步,工业界每天都有创新。编程对于热爱它的人来说...

  • 面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

    经常能在网上听到一些某某公司清退一些35岁以上人员,社长工作也有4年多了,说实话,也有点迷茫,特意百度查了一下30岁程序猿的出路,发现知乎上有这么一个话题,“30岁以上的程序员该何去何从?” 100多w的阅读量...

  • 程序员必须掌握的核心技能有哪些?

    ”说实话,我心目中很多选项,不少于 20 个,但我斟酌再三,只挑选了其中最能让你受益的 8 个,不仅能让领导赏识你,还能让领导给你升职加薪。 01、吃透一门编程语言 这个技能看起来似乎没有必要强调,毕竟程序员不...

  • 求伯君,一个你必须知道的程序员

    我想很多90后从事互联网的孩子知道的一般是马云、马化腾、李彦宏、雷军这些依旧在时代里引领风骚的互联网开创者们,而不知道求伯君这“中国第一程序员”。要知道求伯君是1964年生,而雷军是1969年生,所以其实他们是...

  • 一不小心就触碰红线...程序员必须知道的法律知识有哪些?

    恼火的项目经理在获取真凭实据后开除处分,并且为了以儆效尤,还要求他退还十个月的工资,否则就要对他发起诉讼。此类事件层出不穷,要么是为了从事一些兼职工作,要么是工作粗心等等原因,很多程序员不明确法律规定...

  • 2023,程序员的出路在哪里?

    可是似乎从30岁开始这工资就没涨过,前面跳槽几次涨的薪水在30岁以后跳槽已经不管用了、定格了,这几年由于市场环境不景气,程序员竞争越来越激烈,36岁跟30拿的工资一模一样,不仅工资拿的一样,反而事情还越来越多...

  • 11款程序员实用工具,老少皆宜,你一定用得上

    优秀程序员之所以优秀的原因并不一定是他写代码的速度比所有人都快,但他解决事情的效率一定是比很多人都要高的,提升工作效率的方法并不需要我们十八般武艺样样精通,有时候使用好的工具就能帮助我们大大提升办事...

  • 惹毛程序员的十件事!需求变更居然不是排第一

    本文转载自 程序员编程社区 如何惹毛一名开发者? 再好脾气的程序员,总能被下面一条逼疯,你中了几条呢? 第十位 程序注释 程序注释本来是一些比较好的习惯,当程序员老手带新手的时候,总是会告诉新手,一定要...

  • 老程序员应该记住的 5 件事

    老程序员应该记住的 5 件事 2017年4月26日 by 搬砖工 / 0 32° 如果你甘于现状,并且已经在计划着怎么用退休金了,那么你不是这个帖子的主角。当然还是要恭喜你,已经快熬出头了。但是,如果你同我一样,尽管...

  • 一名合格的程序员应该是什么样子

    ”看源码是一件好事,这是毋庸置疑的,但如果强迫 1 年工作经验不到的程序员去看源码解决问题就属于强人所难了——天赋异禀的除外。 说实话,在我 8 年多的职业生涯中,很少通过看源码解决问题。当然了,你可以...

  • 惹毛程序员的十件事

    下面,让我来看看十件能把程序惹毛了的事情。一方面我们可以看看程序员的共性,另一方面我们也可以看看程序员的缺点。无论怎么样,都希望对你的日常工作都是一种帮助。   第十位 程序注释 程序注释本来是...

  • 程序备忘录:之八-画面迁移表(2004/09/24 15:27)

    时值九月,秋高气爽。(略去感想70字。)近期一直考虑的东西,就是标题所言。从业于WEB开发的人士对画面迁移是异常熟悉,我们常见的一种错误就是画面迁移不正确。就飞速发展的需求而言,从一个画面的ACTION动作,应该考虑它的N种迁移可能性。这里特别要说的是画面迁移随开发的进展有被认为需要改变的可能。举例说,某ACTION处理,条件1,2,3时迁移到A画面,条件4,5,6时迁移到B画面,现在要改为条件6

  • 程序备忘录:之六-判定树的用法(2004/08/23 20:06)

      软件理论很多很杂,而且有很多是借鉴了其它专业的理论。从软件工程的瀑布模型中知道,编码要依据详细设计来完成。判定树是系统分析和设计期的工具,但编码人员不一定每次都能从详细设计书中找到明确的判定树资料。  假定有下面的编码需求:有两个状态变量,每个变量有4种状态值,对两个状态的不同组合共有4种处理方式。可以进行下面的编码(Java例)。    //-------------------------

  • 程序备忘录:之七-状态的联想(2004/08/31 19:10)

      软件测试到了后期,出现了一个奇怪的BUG。几经查找,是因为对DB中某条数据的状态Flag判断不够,从代码中反映为只有IF而没有ELSE,这样反映到系统中就出现了意想不到的效果。一般来说,出现过两次的问题就值得总结一番了,这就引出了本节文字。  开发软件项目要接触到很多与状态有关的东西,如状态迁移。举例如:计划书状态(临时,草稿,校核,审查,审定,批准,发布,归档,作废)。暂时想到了这么多,状态

Global site tag (gtag.js) - Google Analytics