1999年,周星驰拍了一部电影叫做《喜剧之王》,一部令人难忘的作品。片中有个情节,迄今记忆犹新。星爷所饰演的主人公,爱上了一位夜总会的小姐,并且与她发生了关系。醒来之后,他把自己的全部身家都留给了她。这中间包括一块手表、几枚硬币,还有一本书。书的名字,我记得很清楚,叫做《演员的自我修养》。

  多年来,我一直在寻找,一本名为《程序员的自我修养》的书。在我的内心深处,一直有一种隐约的信念:这样的一本书,将能够标志软件行业在精神上的成熟。不过,很可惜,一直到今天,我都没有找到这本书。

  当然,这并不是我写这篇文章的理由。以我的资质,来写这样的大题目,并不相称。所以,不妨将我写下来的这些年对此问题的感悟与思考,看成一个戏作。又或者,在其中还能找到一星半点的真知灼见。

  独立思考

  我一直告诫自己,在这个世界上,绝对意义上的独立思考是不存在的。人的思想,被基因、教育、环境所决定,又随着当下的心境、情绪而起伏。不过,这些都不妨碍我们通过不断的内省和诘问揭示事物的真相。OOP,AOP,MDA,Design Pattern,XP,RUP,TDD,...... 是谁在鼓吹他们?又是谁从中得到了利益?

  思考本身是不容易的,所以我碰到过很多程序员特别热衷于马不停蹄地写代码,很少停下来想一下,为什么这么写?要怎么设计程序才会更好?写出来的这个程序是谁在使用?他们想得到的是什么?一个本来是脑力劳动的行当,被他们做成了体力劳动。

  去思考已属难能,再要做到独立,不为时尚所影响,就更其可贵了。因为,独立不止是一种态度,更是一种能力。也正因为此,才要去修养。而且,作为最基本,最重要的一项。因为,没有独立思考,就很难达成自我教育;而没有自我教育,就谈不上自我修养。

  谦卑之心

  机器不是人的奴隶,程序也不是程序员的仆人。它们的成长顺应其自身内在的规律。程序员的工作,就象农民,只是给程序浇水施肥,给它们好的阳光和空气,帮助它们生长发育。在我们所创造的程序面前保持谦卑之心,当它们运行良好时不必欣喜若狂,当它们崩溃时也不会手足无措。

  对于我们的前辈,也要保持谦卑之心,不要认为他们已经落后于时代。他们曾经直接面对裸露的机器,一个字节一个字节地输入程序;他们曾经为了几个字节的运行空间构思过很多奇妙的设计;他们曾经为了使每天只有5分钟的上机调试时间而反复地检视自己的程序;他们曾经为了减少一个循环而绞尽脑汁。他们精益求精,因为硬件的束缚已经使程序创作变成一门艺术。

  而今天,我们的程序之道,正在退化成一种技术。因为,我们已经失去了我们的前辈们曾有过的谦卑之心。

  简洁之道

  没有一个可用的程序是简单的。但这并非所有程序员的共识。很多程序员认为很多程序是简单的,比如MIS系统。我今天所供职的这家公司生产的几乎全是这类系统,这家公司已经做了十年了,其产品依然令人难堪。因为其产品主题不简洁。

  一个程序要成为一个良好运作的系统,需要处理非常多的细节,应对来自硬件、操作系统、其它软件所带来的故障或异常,成千上万的状态,每一个执行都可能产生若干个逻辑分支。这一切,都使一个完备的程序变得异常复杂。但是,也正因为此,一个程序的主题必须遵循简洁之道。复杂的系统需要简洁清晰的主题来支撑才能站起来,不然就会溃散。

  我们通常所做的恰好相反。我们把一个程序的逻辑想得很简单,同时为了炫耀自己的技术而使细节变得毫无必要的繁复,对于主题,则经常是不加思索,不加约束。一个系统是什么,不是什么,讲了半天,写几百页的文档,还是讲不清楚,不知所云。因为我们没有遵循简洁之道。

  大局观

  在软件界,有一种汹涌的努力,正在企图剥夺一个程序员作为一个思想者的乐趣。他们弘扬大方法论,把系统进行精致的分解,由为数不多的几个设计师控制着系统的设计,程序员则变成纯粹的蓝领。其核心要义,是软件系统可以象建筑物一样来构造,程序员最后可以变成砌砖的人。

  这种努力来势汹汹,而且没有引起人们足够的警觉。尽管还没有见过以这种方式构造的真正革命性的软件产品,它已经在宣称,一个工作中的程序员不需要良好的大局观。如果你是一个普通的程序员,你不需要了解你所写的代码所服务的系统,你不需要了解你的程序服务于什么人,你甚至不需要关心你的程序是否真正进入了系统。

  然而,没有大局观,对系统构造而言是一个长远的伤害,系统最终将变得支离破碎。对系统的每一点更改,都会变得让人难以忍受。而对于程序员来说,没有大局观,又意味着什么呢?这个问题,可是值得好好思考。

  清晰阐述

  我一直相信,一个观念,如果不能够被阐述出来,它就是不清晰的;一个程序员,如果不能阐述其程序的主题,那一定是没有深刻地理解这个程序。也许有人会反驳说程序员一般是内向的,不善言辞,可能能写出好程序,但是却讲不清楚。但是,我所见过的程序员,不论看上去多么木讷,只要谈起他们投入热情所写的程序,马上就会变得滔滔不绝,喜形于色。

  在这个问题上,程序员并不能被作为一个特例来对待。清晰阐述,不仅是一个发表观念的动作,更是一种促进思考的工具。很多的思想,都是在阐述的过程中被得到检视,发现了漏洞,进行了完善,或者经过了更深的验证。因为阐述本身为思考提供了明确的标的物,所以它们极有可能再次激发了新的思考。

  作为团队工作中的一个元素,清晰阐述同时也是团队流畅运作的一个基本需求。在清晰阐述的过程中,程序员发现了自我,并开始突破程序员的职业边界。

  什么是好的程序?好的程序不是使人惊叹,而是触动他们的灵魂。就象桥下的流水,安详优雅地流淌,偶尔碰到礁石,或者激起浪花,但都能够自我包容,毫无阻滞的运行。如果我们能写出这样的程序,那么,我们的自我修养就已经走上了正道。

我相信思考是成功的秘诀,我特别热爱极限攀岩,而且是徒手攀岩,在不断挑战自我,面临死亡的情况下,仍然能够保持清醒的头脑去思考。写程序也是一样的,真的算起来,虽然我写过不少代码,但是写代码占用的时间其实连15%都不到,更多的时间我在思考,在设计,在推敲,在。。。

(杂谈二) 看看别人是怎么写程序的(程序员的自我修养)相关推荐

  1. 在华为写了十几年代码,一个程序员的自我修养

    以下内容来自公众号逆锋起笔,关注每日干货及时送达 本文来自<华为人>徐宏伟,转载请注明出处 一天晚上,我和老婆聊天,说部门要我写个"大咖谈软件"的文章,老婆斜了我一眼, ...

  2. 【读书笔记】【程序员的自我修养 -- 链接、装载与库(二)】进程虚拟地址空间、装载与动态链接、GOT、全局符号表、共享库的组织、DLL、C++与动态链接

    文章目录 前言 介绍 可执行文件的装载与进程 进程虚拟地址空间 装载方式 操作系统对可执行文件的装载 进程虚存空间分布 ELF文件的链接视图和执行视图 堆和栈 Linux 内核装载ELF & ...

  3. 程序员的自我修养(序)-量子

    本人为什么会最终想到要写这一<程序员的自我修养>以及<我的IT生活>,首先周星驰是本人很喜欢的一位演员,<喜剧之王>里的那本<演员的自我修养>,他用他特 ...

  4. 《程序员的自我修养》学习笔记

    程序员的自我修养 第一章 谈职业生涯 1.程序员应该是那些不断追求更高技术,并有着自己产品梦的工匠.当你通过对自己技术不断打磨,一次又一次做出那些优秀产品的时候,你会发现自己不再是他人口中的码农或是屌 ...

  5. 一个“程序员的自我修养”是什么?

    在<喜剧之王>中,周星驰扮演的尹天仇,一直梦想成为一名演员,而他不管是在扮演跑龙套,或者在街坊中开设演员训练班,亦或成为主角时,他对待演员的态度,始终是认真,热爱而又投入的.而那一本他随身 ...

  6. 程序员的自我修养(2)——计算机网络(转) good

    相关文章:程序员的自我修养--操作系统篇 几乎所有的计算机程序,都会牵涉到网络通信.因此,了解计算机基础网络知识,对每一个程序员来说都是异常重要的. 本文在介绍一些基础网络知识的同时,给出了一些高质量 ...

  7. 程序员的自我修养(转载)

    疲于加班,幸好我还保留看看别人写的东西的习惯,下面转载的一篇文章,在某些地方触动到了我,有些时候我也是反面典型,思考得少,反而直接拿来用的更多,但是我发现,往往很多问题都是糊里糊涂地用了别人的东西导致 ...

  8. 论一个程序员的自我修养

    本篇文章转载-转瞬之夏 在<喜剧之王>中,周星驰扮演的尹天仇,一直梦想成为一名演员,而他不管是在扮演跑龙套,或者在街坊中开设演员训练班,亦或成为主角时,他对待演员的态度,始终是认真,热爱而 ...

  9. 【读书笔记】【程序员的自我修养 -- 链接、装载与库(三)】函数调用与栈(this指针、返回值传递临时对象构建栈、运行库与多线程、_main函数、系统调用与中断向量表、Win32、可变参数、大小端

    文章目录 前言 介绍 内存 内存布局 栈与调用惯例 堆与内存管理 运行库 入口函数和程序初始化 C/C++运行库 运行库与多线程 C++全局构造与析构 fread 实现 系统调用与API 系统调用介绍 ...

  10. 一个程序员修炼之道《论程序员的自我修养》

    每个程序员修炼之道都是漫长而艰辛的,要想成为一名伟大的程序员,不仅技术全面还要有程序员的自我修养 程序员修炼之道阶段之: 找到编码的感觉 经过几年的积累,逐渐认识了Java,Python.所学的知识当 ...

最新文章

  1. 在vscode中统一vue编码风格的方法
  2. 千亿参数大模型时代,QQ浏览器团队十亿级小模型「摩天」登顶CLUE
  3. 前沿科技 | 中科院科学家在关于运动规划的环路机制研究方面获进展
  4. 1.计算机的组成(冯诺依曼体系)
  5. linux下静默安装oracle10g,CentOS下远程静默安装Oracle10g笔记
  6. 完全卸载mysql数据库图文教程
  7. jquery ajax是什么意思,Jquery ajax
  8. [2017-08-31]如何使用ruby同步markdown博文到博客园
  9. Python问题记录:如何处理中文网页中的多余空格
  10. nginx ---- 背景介绍及环境准备
  11. 动软代码生成器连接8.0.17版本的mysql
  12. matlab数据归一化mapminmax函数
  13. 大咖说|翼辉丁晓华:我们已经真正意义上感受到了原始创新带来的巨大价值
  14. kubectl config 命令
  15. SPARK 笔记 (五) 经纬度转换地址
  16. 一次软件测试的电话面试分享
  17. 功能中进行频繁查询、提高查询效率的方法
  18. ODT在手,DDR5布线可以任性走?
  19. 微信小程序(小程序的生命周期)
  20. 品论文:VISION TRANSFORMER (VIT)

热门文章

  1. JAVA集合中常见的List和Map用法
  2. Emule服务器与设置
  3. python实时监控网站更新_Python监控Github项目更新并自动下载
  4. 根据不同时区来计算当前时间
  5. HBuilderX 导入uniapp后,无法运行或发行,提示“[微信小程序开发者工具] × open IDE”
  6. go 连接服务器 并存放图片_[本站大事件] 又更换服务器了 – 小文's blog
  7. CF - 1156D - 0-1-Tree
  8. 十四、中国为什么没有自己的指令集
  9. 使用 SASS 混合器 和@media 适应分辨率变化
  10. 李嘉诚14句经典成功格言