ALGOL
维基百科,自由的 encyclopedia
ALGOL,名称源自演算法语言(英语:ALGOrithmic Language)的缩写[1],是一族指令式编程语言,发展于1950年代中期,对许多其它程式语言产生了重大影响。计算机协会在教科书及学术文章采用此语言做为描述演算法的标准语法超过三十年。[2]
此条目可参照英语维基百科相应条目来扩充。 |
Quick Facts 编程范型, 设计者 ...
编程范型 | 过程式, 指令式, 结构化 |
---|---|
设计者 | Bauer, Bottenbruch, Rutishauser, Samelson, Backus, Katz, Perlis, Wegstein, Naur, Vauquois, van Wijngaarden, Woodger, Green, McCarthy |
发行时间 | 1958年,66年前(1958) |
当前版本 |
|
影响语言 | |
许多后来的命令式语言(被称作ALGOL-like语言) e.g. Simula, C, CPL, Pascal, Ada 受ALGOL影响的函数式语言:Scheme |
Close
由大多数近代程式语言皆使用类似ALGOL的语法来看[3],ALGOL可与差不多同时期的FORTRAN、LISP及COBOL并列为四大最有影响力的高阶语言[4]。ALGOL被设计用来避免FORTRAN中一些已知的问题,最终引领了许多其它程式语言的兴起,包括PL/I、Simula、BCPL、B、Pascal及C。
ALGOL引入了代码块,并用begin
⋯end
来分隔。它是第一个利用词法作用域实作巢状函式的语言,也是第一个注重形式语言定义的语言,并在ALGOL 60报告中引入了巴科斯范式来作为设计语言形式文法的原则。
ALGOL主要有三种规格,以初次发表的年份命名:
- ALGOL 58 – 原提议命名为IAL,代表International Algebraic Language。
- ALGOL 60 – 在1960年代中期首先实作成X1 ALGOL 60,1963年修订。[5][6]
- ALGOL 68 – 引入许多新元素,像是可变阵列、切片、平行化及算子识别。1973年修订。[7]
尼克劳斯·维尔特在发展Pascal之前,在ALGOL 60的基础下建立了ALGOL W。ALGOL W本是下一代ALGOL的提议,但ALGOL委员会决定采用更先进复杂的设计,而不是一个简洁化ALGOL 60。