程序员修炼之道----从小工到专家(参考指南)

其实不只是说程序员的修炼之道,也是人生的修炼之道。

1、Care Abort Your Craft关心你的技艺

如果你不在乎能否漂亮的开发出软件,你又何必要耗费生命去开发软件呢?
要深入的了解你所使用的技术。要知其然知其所以然。

2、Think! Abort Your Work思考!你的工作

关掉自动驾驶仪,接管操作,不断地批评和评估你的工作

3、Provide Options, Don't Make Lame Excuses提供各种选择,不要找蹩脚的借口

提供各种选择,而不是找借口,不要说事情做不到 ,说明做到了什么。

4、Don't Live with Broken Windows不要容忍破窗户

当你看到糟糕的设计、错误的决策或者不好的代码时,修正他们

5、Be a Catalyst for Change做变化的催化剂

你不能强迫人们改变,想法,你要向他们展示未来可能会怎样,并帮助他们参与对未来的创造

6、Remember the Big Picture记住大图景

不要太过专注于细节,以致忘了查看你周围正在发生什么

7、Make Quality a Requirements Issue使质量成为需求问题

让你的用户参与确定项目真正的质量需求

8、Invest Regularly in Your Knowledge Portfolio定期为你的只是资产投资

让学习成为习惯

9、Critically Analyze What You Read and Hear批评地分析你读到的和听到的

不要被供应商、媒体炒作或教条左右。要依照你自己的看法和你项目的情况去对信息进行分析

10、It's Both What You Say and the Way You Say It你说什么和你怎么说同样重要

如果你不能有效地向他人传达你的了不起的想法,这些想法毫无用处

11、DRY --- Don't Repeat Yourself不要重复你自己

系统中的每一项知识都必须具有单一、无歧义、权威的表示

12、Make It Easy to Reuse让复用变得容易

如果复用很容易,人们就会去复用,创造一个支持复用的环境

13、Eliminate Effects Between Unrelated Things消除无关事物之间的影响

设计自足、独立、并具有单一、良好定义的目的的组件

14、There Are No Final Decisions不存在最终决策

没有决策时浇铸在石头上的,想法,要把每项决策都视为是写在沙滩上的,并为变化做好计划

15、Use Tracer Bullets to Find the Target用曳光弹找到目标

曳光弹能通过试验各种事物并检查它们离目标有多远来让你追踪目标

16、Prototype to Leam为了学习而制作原型

原型制作是一种学习经验,其价值并不在于所产生的代码,而在于所学到的经验教训

17、Program Close to the Problem domain 靠近问题领域编程**)

用你的用户的语言进行设计和编码

18、Estimate to Avoid Surprises估算,以避免发生意外

在着手之前先进行估算,你将提前发现潜在的问题

19、Iterate the Schedule with the Code通过代码对进度表进行迭代

用你在进行实现时获得的经验提炼项目的时间标度

20、Keep Knowledg in Plain Text用纯文本保存知识

纯文本不会过时,它能够帮助你有效利用你的工作,并简化调试和测试。

21、Use the Power of Command Shells利用命令shell的力量

当图形用户界面无能为力时使用shell

22、Use a Single Editor Well用好一种编辑器

编辑器应该是你的手的延伸,确保你的编辑器是可配置,可扩展和可编程的

23、Always Use Source Code Control总是使用源码控制

源码控制是你的工作的时间机器-----你能够回到过去

24、Fix the Problem,Not the Blame要修正问题,而不是发出指责

Bug 是你的过错还是别人的过错,并不是真的很有关系-----它仍然是你的问题,他仍然需要修正

25、Don't Panic When Debuging调试时不要慌张

做一次深呼吸,思考什么可能是bug的原因

26、“”Select“ Isn't Broken”"Select"没有问题

在OS或者编译器,甚或是第三方产品或库中很少发现bug,bug可能在应用中

27、Don't Assume It ---Prove It不要假定,要证明

在实际环境中,使用真正的数据和边界条件,证明你的假定

28、Learn a Text manipulation Language学习一种文本操作语言

你每天的很大一部分时间处理文本,为什么不让计算机替你完成部分工作呢?

29、Write Code That Writes Code编写能编写代码的代码

代码生成器能提高你的生成率,并有助于避免重复

30、You Can't Write Perfect Software你不可能写出完美的软件

软件不可能完美,保护你的代码和用户。使他们免于能够预见的错误

31、Design With Contracts通过合约进行设计

使用合约建立文档,并检验代码所做的事情证号是她声明要做的

32、Crash Early早崩溃

死程序造成的危害通常比有问题的程序要小的多

33、Use Assertions to Pervent the Impossible用断言避免不可能发生的事情

断言验证你的各种假定,在一个不确定的世界里,用断言保护你的代码

34、Use Exceptions for Exceptional Problems将异常用于异常的问题

异常可能会遭受经典的意大利面条式的所有可读性和可维护性问题的折磨。将异常保留给异常的事物

35、Finish What You Start要有始有终

只要可能,分配某资源的例程或对象也应该负责接触其分配

36、Minimize Coupling Between Modules使模块之间的耦合减至最少

通过编写“羞怯的”代码并应用德墨忒尔法则来避免耦合

37、Configure, Don't Integrate要配置,不要集成

要将应用得各种技术选择实现为配置选项,而不是通过集成或工程方法实现

38、Put Abstactions in Code ,Details in Metadata将抽象放进代码,细节放进元数据

为一般情况编程,将细节放在被编译的代码库之外

39、Analyze Workflow to Improve Concurrency分析工作流,以改善并发性

利用你的用户的工作流中的并发性

40、Design Using Services用服务进行设计

根据服务(独立的,良好定义,一致的接口之后的并发对象)进行设计

41、Always Design for Concurrency总是为并发进行设计

容许并发,你将会设计出更整洁,具备更少假定的接口

42、Separate Views from Models使视图与模型分离

要根据模型和视图设计你的应用,从而以低廉的代码获取灵活性

43、Use Blackboards to Coordinate Workflow用黑板协调工作流

用黑板协调完全不同的实施和因素,同时又使各参与方保持独立和隔离

44、Don't Program by Coincidence不要靠巧合编程

之一开可靠的事物,注意偶发的复杂性,不要把幸运的巧合与有目的的计划混为一谈

45、Estimate the Order of Your Algorithms估算你的算法的阶

在你编写代码之前,先大致估算事情需要多长时间

46、Test Your Estimates测试你的估算

对算法的数学分析并不会告诉你每一件事情,在你的代码的目标环境中测定它的速度

47、Refactor Early,Refactor Often早重构,常重构

就和你会在花园里除草,并重新布置一样,在需要时对代码进行重写,重做和重新架构,要铲除问题的根源

48、Design to Test为测试而设计

在你还没有编写代码时就开始思考测试问题

49、Test Your Software ,or Your Users Will测试你的软件,否则你的用户就得测试

无情的测试,不要让你的用户为你查找Bug

50、Don't Use Wizard Code You Don't Understand不要使用你不理解的向导代码

向导可以生成大量代码,在你把他们合并进你的项目之前,确保你理解全部这些代码

51、Don't Gather Requirements ----Dig for Them不要搜集需求----挖掘它们

需求很少存在于表面上,它们深深地埋藏在层层假定、误解和政治手段的下面

52、Work with a User to Think Like a User与用户一同工作,以像用户一样思考

要了解系统实际上将如何被使用,这是最好的方法

53、Abstractions Live Longer than Details抽象比细节活得更长久

“投资”于抽象,而不是实现,抽象能在来自不同的实现和新技术的变化“攻击”之下存活下去

54、Use a Project Glossary使用项目词汇表

创建并维护项目中使用的专用术语和词汇的单一信息源

55、Don't Thank Outside the Box --- Find the Box不要在盒子外面思考----要找到盒子

在遇到不可能解决的问题时,要确定真正的约束,问问自己:“它必须以这种方式完成吗?它真的必须完成吗?”

56、Start When You're Ready等你准备好再开始

你的一生都在积累经验,不要忽视反复出现的疑虑

57、Some Things Are Better Done than Described对有些事情“做”胜于“描述”

不要掉进规范的螺旋。在某个时刻,你需要开始编码

58、Don't Be Slave to Formal Methods不要做形式方法的奴隶

如果你没有把某项技术放进你的开发实践和能力的语境中,不要盲目的采用它

59、Costly Tools Don't Produce Better Designs昂贵的工具不一定能制作出更好的设计

小心供应商的炒作,行业教条,以及价格标签的诱惑,要根据工具的价值判断它们。

60、Organize Teams Around Functionality围绕功能组织团队

不要把设计师与编码员分开,也不要把测试员与数据建模员分开,按照你构建代码的方式构建团队

61、Don't Use Manual Procedures不要使用手工流程

shell 脚本或批文件会一次次地以同一顺序执行同样的指令

62、Test Early.Test Often.Test Automatically早测试,常测试,自动测试

与呆在书架上的测试计划相比,每次构建时运行的测试要有效得多

63、Coding Ain't Done.Til All the Tests Run 要通过全部测试,编码才算完成**)

所有的代码都需要测试一遍,才能算完成了编码

64、Use Saboteurs to Test Your Testing 通过“蓄意破坏”测试你的测试**)

在单独的软件副本上故意引入Bug,以检验测试能够抓住它们。

65、Test State Coverage,Not Code coverage测试状态覆盖,而不是代码覆盖

确定并测试重要的程序状态,只是测试代码行是不够的。

66、Find Bug Once一个Bug只抓一次

一旦测试员找到一个bug,这应该是测试员最后一次找到它。伺候自动测试应该对其进行检查

67、English is Just a Programming Language阴雨就是一种编程语言

像你编写代码一样编写文档,遵守DRY原则,使用元数据、MVC、自动生成等等

68、Build Documentation In, Don't Bolt It On把文档建在里面,不要拴在外面

与代码分离的文档不太可能被修正和更新

69、Gently Exceed Your Users' Expectations温和地超出用户的期望

要理解你的用户的期望,然后给他们的东西要多那么一点。

70、Sign Your Work在你的作品上签名

过去时代的受益人为能在他们的作品上签名而自豪、你也应该如此

你可能感兴趣的:(程序员修炼之道----从小工到专家(参考指南))