目录

格林斯潘第十定律

格林斯潘第十定律

格林斯潘第十定律 是 领域,尤其是 领域的一句 :

任何足够复杂的 或者 程序中,都包含一个临时特设的、不合规范的、充满 的、运行速度很慢的、只有一半功能的 实现。

这表现了 语言的灵活性和可扩展性,它包含了理论上编写复杂计算机程序需要的所有功能。而其他编程语言的核心实现却不能提供开发复杂程序的关键性功能支持。

来源

该定律由 (Philip Greenspun)于1993年前后提出。尽管被称作“第十定律”,然而实际上并没有前九个定律。格林斯潘曾说这只是为了更好记。

含义

Lisp语法几乎是抽象的,其程序以 形式构建,这等价于其他编程语言内置 中的 。Lisp作为一种 (homoiconic)的语言,不区分代码与数据,即:Lisp程序本身即Lisp数据结构。Lisp程序自身可通过 生成额外的Lisp程序。因此,程序员可以相对轻松地构建复杂的特定领域语言。

如同 所说,Lisp比起其他语言可以更快地构建更健壮的程序。

格林斯潘第十定律表示,任何复杂软件系统都需要上述的功能,都将从头到尾重新设计开发这一套系统,而这在 中已经存在了。

莫里斯推论

知名 给该定律加上推论:

……包括 。

可以被认为是对编写庞大而复杂的 程序困难性的评论,或仅仅是对于Lisp中eval函数的幽默。

格林斯潘第十定律和莫里斯推论都具备 中“哈哈,但的确如此”的风格特征。