`

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 哲学.pdf

    Unix 哲学 Unix 哲学 Unix 哲学 Unix 哲学 Unix 哲学 Unix 哲学 Unix 哲学

    Python-FeelUOwn是一个符合Unix哲学的跨平台的音乐播放器主要面向LinuxmacOS用户

    **Python-FeelUOwn:一个面向Unix哲学的跨平台音乐播放器** Python-FeelUOwn,简称FeelUOwn,是一款专为Linux和macOS用户设计的音乐播放器,它遵循了Unix哲学,即“做一件事并做好”。这个开源项目以其简洁易用的...

    UNIX编程哲学-中文版

    ”这句话深刻揭示了理解和掌握UNIX哲学的重要性。 #### 2. 文化的传承与学习 - **文化与传统**:UNIX不仅是一种操作系统,更代表了一种文化。书中提及的“文化”、“艺术”和“哲学”,指的是在UNIX社区中流传下来...

    unix-philosophy:为 YYCJS 所做的关于模块化和 unix 哲学的演讲

    在 IT 领域,Unix 操作系统及其背后的哲学对软件设计和开发有着深远的影响。这次的演讲主题“unix-philosophy”旨在探讨 Unix 的核心原则如何应用于现代的模块化编程,特别是针对 JavaScript(YYCJS)社区。Unix ...

    LINUX+UNIX设计思想

    《Linux\Unix设计思想/图灵程序设计丛书》内容简介:将Linux的开发方式与Unix的原理有效地结合起来,总结出Linux与Unix软件开发中的设计原则。《Linux\Unix设计思想/图灵...最后介绍了Unix哲学准则在其他领域中的应用。

    Unix philosophy

    **Unix哲学** Unix哲学是操作系统设计的核心理念,它源自于1960年代末到1970年代初开发的Unix系统。这个哲学强调的是简洁、模块化和可组合性的原则,旨在创建高效、可靠且易于维护的软件系统。Unix哲学的影响深远,...

    UNIX编程艺术全部目录

    书中首先介绍了UNIX哲学,包括其文化背景、生命力以及一些反对观点。UNIX哲学强调模块化、清晰性、组合性、分离、简洁、吝啬、透明性、健壮性、表示原则等16个原则。这些原则指导着开发者如何创建高效、可维护的软件...

    unix 教学课件 unix 教学课件 unix 教学课件

    2. **Unix哲学**:Unix的设计理念,包括“做一件事并做好它”、“小即是美”以及“工具间的可组合性”。 3. **Unix shell**:讲解Bash或其他shell(如Csh、Ksh)的使用,包括命令行界面、命令语法、脚本编写等。 4...

    Unix编程艺术/Unix环境高级编程(第二版)/Unix网络编程(第二版)

    从基础的Unix哲学到高级的系统编程,再到复杂的网络通信,构成了一个完整的知识体系。通过深入学习,读者不仅可以提高在Unix环境下的编程能力,还能建立起对操作系统和网络通信的深入理解,这对于任何在Unix或类Unix...

    unix

    Unix哲学鼓励小而专的工具,通过管道(pipe)和重定向(redirect)将它们组合起来解决复杂任务。例如,可以使用`find`查找文件,然后通过管道将其结果传递给`xargs`执行其他操作,如删除找到的文件。这种工具组合的...

    [Unix编程环境]The.unix.programming.envirment中文版

    无论是对于想要了解UNIX哲学的学习者,还是希望深入UNIX编程的专业开发者,本书都是一本不可多得的学习资源。 在学习UNIX和C语言的过程中,实际操作和动手编程同样重要。本书鼓励读者在计算机上实践所学知识,并...

    Unix的学习课件

    2. **Unix哲学**:Unix的设计哲学强调模块化和小型工具的组合,提倡“做一件事并做好”。这种哲学体现在Unix的命令行工具和管道机制中,用户可以通过简单的命令组合完成复杂的任务。 3. **文件系统**:Unix的文件...

    Unix经典书合集

    这本书不仅仅是一本关于Unix编程的书,更是一部阐述Unix哲学和设计原则的著作。Raymond在书中倡导简洁、模块化、可移植的编程风格,讲解了Unix工具和命令行接口的设计思想,以及如何利用Unix系统特性进行高效的软件...

    unix课件 ppt格式文件

    这些系统虽然在细节上有所不同,但都遵循了Unix哲学,即"做一件事并做好"。 【总结】 这个Unix课件主要涵盖了Unix系统的基本概念、核心组件、文件系统、进程管理、网络编程和脚本编写等方面,通过7张PPT内容,将...

    sx是旨在遵循UNIX哲学的命令行网络扫描程序。-Golang开发

    sx是旨在遵循UNIX哲学的命令行网络扫描程序。 该项目的目标是使用干净,简单的代码创建最快的网络扫描仪。 :open_book:目录功能从源代码构建快速入门参考贡献信用许可证:sparkles:功能:high_voltage:比nmap ARP扫描...

    UNIX课本习题答案

    1. **UNIX基础知识**:这可能包括UNIX的历史、主要版本(如BSD、System V、Linux等)的区别、以及UNIX哲学的讲解。 2. **文件系统与目录结构**:习题可能会涉及`/bin`, `/usr`, `/etc`, `/home`等常见目录的作用,...

Global site tag (gtag.js) - Google Analytics