【读书笔记】linux编程艺术

时间:2022-03-20 04:41:40

一、哲学

1、Rule of Modularity: Write simple parts connected by clean interfaces.
1、模块原则:尽量使用简洁的接口套和简单的组件。
2、Rule of Clarity: Clarity is better than cleverness.
2、清晰原则:清晰胜于取巧。
3、Rule of Composition: Design programs to be connected to other programs.
3、组合原则:设计时,要考虑连接组合。
4、Rule of Separation: Separate policy from mechanism; separate interfaces from engines.
4、分离原则:策略同机制分离,接口同引擎分离。
5、Rule of Simplicity: Design for simplicity; add complexity only where you must.
5、简洁原则:设计尽可能简洁,复杂度能低则低。

6、Rule of Parsimony: Write a big program only when it is clear by demonstration that  
nothing else will do.
6、吝啬原则:除非别无他法,否则,不要去编写庞大的程序。
这点,跟上第5点差不多,以简洁为美,不要刻意去编写庞大而复杂的程序。

7、Rule of Transparency: Design for visibility to make inspection and debugging easier.
7、透明原则:设计要透明可见,以便审查和调试。
充分考虑透明性、显见性、简洁性。

8、Rule of Robustness: Robustness is the child of transparency and simplicity.
8、健壮原则:健壮的程序源于透明与简洁。
程序越简洁,越透明,程序就越健壮。

9、Rule of Representation: Fold knowledge into data so program logic can be stupid and  
robust.
9、表示(法)原则:把知识叠入数据,以求逻辑结构质朴而健壮。
建模,以求逻辑结构清晰。

10、Rule of Least Surprise: In interface design, always do the least surprising thing.
10、通俗原则:接口设计,避免标新立异。
程序的好坏由用户来评判,最简单易用、最通俗易懂的程序,往往是最受用户欢迎的程序。

11、Rule of Silence: When a program has nothing surprising to say, it should say nothing.
11、缄默原则:如果一个程序没什么好挑剔的,那就保持沉默。
程序不要有多余冗杂的部分,尽量简洁为上,不需要的多余功能,就不要有。

12、Rule of Repair: When you must fail, fail noisily and as soon as possible.
12、补救原则:出现异常时,马上退出并适当给出足够的出错信息。
尽可能让程序以一种容易诊断出错误的方式终止掉。

13、Rule of Economy: Programmer time is expensive; conserve it in preference to machine  
time.
13、经济原则:宁可多花机器一分,也不浪费程序员一秒。
时刻记住,程序员的时间是宝贵的,不要无故浪费一分一秒。

14、Rule of Generation: Avoid hand-hacking; write programs to write programs when you can.
14、生成原则:避免手工hack(直译了),尽可能编写程序,让程序去生成程序。
程序规格越简单,设计者就越容易做对。

15、Rule of Optimization: Prototype before polishing. Get it working before you optimize it.
15、优化原则:雕刻前先要有模型,跑之前,要先学会走。
先制作原型,再精雕细琢。优化之前,先确保能用。否则,一切美妙的优化,都是白搭。
或者如,极限编程大师 Kent Beck所说,先求运行,再求正确,最后求快。

不要一味的去考虑那些蝇头小利的所谓效率提升,尽量不要去过早优化,是一切万恶之根源。

16、Rule of Diversity: Distrust all claims for "one true way".
16、多样原则:绝不要去相信什么所谓"不二法则"的言论。
即使最出色的软件,也常常会受限于设计者的想象力。
爱因斯坦曾说过一句话,这个世界缺乏的不是技术,而是想象力。

没有人能聪明到把所有的东西,都能事先预言安排好。

17、Rule of Extensibility: Design for the future, because it will be here sooner than you  
think.
17、扩展原则:设计要着眼于未来,因为有时未来来的要比想象中的快。

二、历史-双流记

1983年 Richard M.Stallman创建了GNU项目

1986年 发明patch的larry wall开始开发Perl语言

一开始unix系统被AT&T SUN IBM掌控,一份源码许可证要4万美元

1991年 linus torvalds 宣布了linux项目

1992年 386BSD 发布

在旧学派的unix开发者中,部分聪明者注意到,做了多年的平价Unix之梦从一个意想不到的方向悄然城镇。

它既不是来自AT&T,也不是SUN,或者任何一个传统厂商,也不是出自学术界有组织的工作成果。它就这样从Internet的石头缝中跳了出来,浑然天成,以令人惊奇的方式重新规划拼装了Unix的传统元素。

黑客的起源和历史:1961-1995

从社会性而言,他们年轻,天资过人,几乎全是男性,献身编程达到痴迷的地步,决不墨守成规--后来被人们唤作“极客(geek)”。他们往往也是头发蓬松的嬉皮士和准嬉皮士。他们有远见,把计算机看作构建社区的工具。他们读Robert Heinlein和J.RR.Tolkien的书,参加复古协会,双关语说起来没完,抛开这些怪癖,他们中的许多人都跻身世界上最聪明的程序员之列。

1995年,linux找到了自己的杀手级应用----开源的web服务器Apache

用*软件是因为它运行得更好,而不是说“用*软件是因为所有软件都该是*的”

“开源”明显要用一个意识形态中性的公众标签来取代Stallman钟爱的“*软件”

在Unix历史中,最大的规律就是:距开源越近就越繁荣。

过度依赖任何一种技术或者商业模式都是错误的----相反,保持软件及其设计传统的灵活性才是长存之道。别和低价而灵活的方案较劲。

三、unix哲学和其他哲学对比

unix统一性的理念或象征最重要一点: “一切皆文件”模型及在此基础上建立的管道概念。