转自http://blog.chinaunix.net/u2/87718/showart_1838217.html
--摘自《UNIX编程艺术》
Unix哲学起源于Ken Thompson早期关于如何设计一个服务接口简洁、小巧精干的操作系统的思考,随着Unix文化在学习如何尽可能发掘Thompson设计思想的过程中不断成长,同时一路上还从其它许多地方博采众长。
Unix哲学说来不算是一种正规设计方法。它并不打算从计算机科学的理论高度来产生理论上完美的软件。那些毫无动力、松松垮垮而且薪水微薄的程序员们,能在短短期限内,如同神灵附体般造出稳定而新颖的软件——这只不过是经理人永远的梦呓罢了。
Unix哲学(同其它工程领域的民间传统一样)是自下而上的,而不是自上而下的。Unix哲学注重实效,立足于丰富的经验。你不会在正规方法学和标准中找到它,它更接近于隐性的半本能的知识,即Unix文化所传播的专业经验。它鼓励那种分清轻重缓急的感觉,以及怀疑一切的态度,并鼓励你以幽默达观的态度对待这些。
Unix管道的发明人、Unix传统的奠基人之一Doug McIlroy在[McIlroy78]中曾经说过:
(i)让每个程序就做好一件事。如果有新任务,就重新开始,不要往原程序中加入新功能而搞得复杂。
(ii)假定每个程序的输出都会成为另一个程序的输入,哪怕那个程序还是未知的。输出中不要有无关的信息干扰。避免使用严格的分栏格式和二进制格式输入。不要坚持使用交互式输入。
(ⅲ)尽可能早地将设计和编译的软件投入试用, 哪怕是操作系统也不例外,理想情况下, 应该是在几星期内。对拙劣的代码别犹豫,扔掉重写。
(iv)优先使用工具而不是拙劣的帮助来减轻编程任务的负担。工欲善其事,必先利其器。
后来他这样总结道(引自《Unix的四分之一世纪》(A Quarter Century of Unix [Salus])):
Unix哲学是这样的:一个程序只做一件事,并做好。程序要能协作。程序要能处理文本流,因为这是最通用的接口。
Rob Pike, 最伟大的C语言大师之一, 在《Notes on C Programming》中从另一个稍微不同的角度表述了Unix的哲学[Pike]:
原则1:你无法断定程序会在什么地方耗费运行时间。瓶颈经常出现在想不到的地方,所以别急于胡乱找个地方改代码,除非你已经证实那儿就是瓶颈所在。
原则2:估量。在你没对代码进行估量,特别是没找到最耗时的那部分之前,别去优化速度。
原则3:花哨的算法在n很小时通常很慢,而n通常很小。花哨算法的常数复杂度很大。除非你确定n总是很大,否则不要用花哨算法(即使n很大,也优先考虑原则2)。
原则4:花哨的算法比简单算法更容易出bug、更难实现。尽量使用简单的算法配合简单的数据结构。
原则5:数据压倒一切。如果已经选择了正确的数据结构并且把一切都组织得井井有条,正确的算法也就不言自明。编程的核心是数据结构,而不是算法[7]。
原则6:没有原则6。
Ken Thompson——Unix最初版本的设计者和实现者,禅宗偈语般地对Pike的原则4作了强调:
拿不准就穷举。
Unix哲学中更多的内容不是这些先哲们口头表述出来的,而是由他们所作的一切和Unix本身所作出的榜样体现出来的。从整体上来说,可以概括为以下几点:
1. 模块原则:使用简洁的接口拼合简单的部件。
2. 清晰原则:清晰胜于机巧。
3. 组合原则:设计时考虑拼接组合。
4. 分离原则:策略同机制分离,接口同引擎分离。
5. 简洁原则:设计要简洁,复杂度能低则低。
6. 吝啬原则:除非确无它法,不要编写庞大的程序。
7. 透明性原则:设计要可见,以便审查和调试。
8. 健壮原则:健壮源于透明与简洁。
9. 表示原则:把知识叠入数据以求逻辑质朴而健壮。
10. 通俗原则:接口设计避免标新立异。
11. 缄默原则:如果一个程序没什么好说的,就沉默。
12. 补救原则:出现异常时,马上退出并给出足够错误信息。
13. 经济原则:宁花机器一分,不花程序员一秒。
14. 生成原则:避免手工hack,尽量编写程序去生成程序。
15. 优化原则:雕琢前先要有原型,跑之前先学会走。
16. 多样原则:决不相信所谓“不二法门”的断言。
17. 扩展原则:设计着眼未来,未来总比预想来得快。
如果刚开始接触Unix,这些原则值得好好体味一番。谈软件工程的文章常常会推荐大部分的这些原则,但是大多数其它操作系统缺乏恰当的工具和传统将这些准则付诸实践,所以,多数的程序员还不能自始至终地贯彻这些原则。蹩脚的工具、糟糕的设计、过度的劳作和臃肿的代码对他们已经是家常便饭了;他们奇怪,Unix的玩家有什么好烦的呢。
分享到:
相关推荐
”这句话深刻揭示了理解和掌握UNIX哲学的重要性。 #### 2. 文化的传承与学习 - **文化与传统**:UNIX不仅是一种操作系统,更代表了一种文化。书中提及的“文化”、“艺术”和“哲学”,指的是在UNIX社区中流传下来...
2. **Unix哲学**:Unix的设计哲学强调“做一件事,并做好”。这一原则体现在Unix工具的小巧、单一功能以及通过管道(pipe)连接工具以完成复杂任务的方式。 3. **文件系统**:Unix的文件系统采用树状结构,一切皆为...
2. **Unix哲学**:Unix哲学强调"做一件事,做好它",体现在其命令行工具的模块化设计上。这些小工具通过管道(pipe)连接,可以构建出复杂的任务处理流程。 3. **Shell**:Unix的Shell是用户与系统交互的界面,如...
在IT领域,Unix操作系统是一个历史悠久且广泛应用于服务器、科研及工程计算的重要系统。这篇"Unix教程基础篇"将引领我们走进Unix的世界,...在深入学习后,你会发现Unix不仅是一个操作系统,更是一种高效的工作哲学。
在IT领域,Linux和Unix是两种广泛使用的操作系统,它们基于同样的Unix哲学,为开发者提供了强大的命令行工具和开放源码环境。本学习资料主要涵盖了Linux和Unix的基础编程知识,包括了14个章节,旨在帮助初学者掌握...
这些操作系统虽然各具特色,但都遵循UNIX的设计哲学和核心原则。UNIX系统设计的核心是分解复杂问题,通过简单的模块组合来解决问题,这种设计理念体现在它的命令行界面、文件系统和系统架构中。 UNIX系统的一个显著...
它的设计哲学是简洁性和可移植性,使得UNIX在各种硬件平台上得到了广泛的应用。本教程讲义将带你深入理解UNIX的基础概念、核心特性以及高级功能。 **第一章:UNIX历史与哲学** UNIX的诞生源自于一个小型项目,由肯...
**UNIX系统基础** UNIX系统是一种历史悠久且广泛使用的操作系统,它为用户提供了一个强大的命令行...在不断探索和使用中,你会发现UNIX不仅仅是一个操作系统,更是一种哲学,一种对简单、优雅和高效解决方案的追求。
在IT领域,Unix系统是最早期的多用户、多任务操作系统之一,它的设计哲学和功能特性对后来的许多操作系统,包括Linux和Mac OS X,都有着深远的影响。本篇将深入探讨Unix系统的基础知识,帮助读者建立对这个强大操作...
5. **简洁高效**:UNIX的设计哲学强调简洁和效率,使得系统响应快速,资源管理优化。 ### UNIX文件系统的结构 UNIX采用层次化的文件系统结构,形象地比喻为“文件树”。根目录`/`位于树的顶部,所有其他目录和文件...
Linux则是基于Unix哲学的开源操作系统内核,由林纳斯·托瓦兹于1991年创建。Linux发行版如Ubuntu、CentOS、Fedora等都是在Linux内核基础上构建的,它们提供了与Unix类似的命令行环境和许多Unix工具。 本教程的基础...
【UNIX操作系统基础】 UNIX操作系统是一种历史悠久、广泛应用的多用户、多任务操作系统,具有高度的可移植性和网络通信功能。从1969年发展至今,UNIX已经覆盖了从微型计算机到巨型计算机的各种平台,成为科学计算、...
首先,Unix是1969年由肯·汤普逊和丹尼斯·里奇在贝尔实验室开发的操作系统,它的设计哲学强调简洁性和可移植性。Unix提供了丰富的命令行界面,用户可以通过输入命令来执行各种任务,如文件管理、进程控制、网络通信...
Unix哲学强调“小即是美”,提倡通过简单、可组合的命令行工具来完成任务。这种理念使得Unix具有极高的灵活性和可扩展性。 **三、Unix shell** Shell是Unix系统中的命令解释器,用户通过shell与系统交互。常见的...
理解Unix哲学,如“做一件事,并做好”原则。 2. **Unix shell**:解释什么是shell,它是如何作为用户与系统交互的接口。学习bash(Bourne Again SHell)的基本命令,如cd、ls、mkdir、rm等,以及shell脚本编写基础...
首先,Linux操作系统是建立在Unix哲学基础上的,其内核负责管理硬件资源,提供系统调用接口供用户空间的程序使用。了解操作系统的基本概念,如进程、线程、内存管理和I/O模型,是Linux编程的基础。在Linux环境中,...
通过《UNIX程序员手册》,新手不仅可以学习到UNIX系统的基础知识,还能深入理解其设计哲学和工作原理,为后续的系统级编程和高级应用开发打下坚实基础。这本书不仅是入门工具,更是长期参考资料,值得反复研读和实践...