Can programming be liberated from the von Neumann style?

冯·诺依曼建筑 函数式程序设计 计算机科学 编程风格 程序设计语言 域代数上的 风格(视觉艺术) 语义学(计算机科学) 代数表达式 程序设计范式 理论计算机科学 代数数 数学 纯数学 数学分析 历史 考古
作者
J. W. Backus
出处
期刊:Communications of The ACM [Association for Computing Machinery]
卷期号:21 (8): 613-641 被引量:2194
标识
DOI:10.1145/359576.359579
摘要

Conventional programming languages are growing ever more enormous, but not stronger. Inherent defects at the most basic level cause them to be both fat and weak: their primitive word-at-a-time style of programming inherited from their common ancestor—the von Neumann computer, their close coupling of semantics to state transitions, their division of programming into a world of expressions and a world of statements, their inability to effectively use powerful combining forms for building new programs from existing ones, and their lack of useful mathematical properties for reasoning about programs. An alternative functional style of programming is founded on the use of combining forms for creating programs. Functional programs deal with structured data, are often nonrepetitive and nonrecursive, are hierarchically constructed, do not name their arguments, and do not require the complex machinery of procedure declarations to become generally applicable. Combining forms can use high level programs to build still higher level ones in a style not possible in conventional languages. Associated with the functional style of programming is an algebra of programs whose variables range over programs and whose operations are combining forms. This algebra can be used to transform programs and to solve equations whose “unknowns” are programs in much the same way one transforms equations in high school algebra. These transformations are given by algebraic laws and are carried out in the same language in which programs are written. Combining forms are chosen not only for their programming power but also for the power of their associated algebraic laws. General theorems of the algebra give the detailed behavior and termination conditions for large classes of programs. A new class of computing systems uses the functional programming style both in its programming language and in its state transition rules. Unlike von Neumann languages, these systems have semantics loosely coupled to states—only one state transition occurs per major computation.

科研通智能强力驱动
Strongly Powered by AbleSci AI
科研通是完全免费的文献互助平台,具备全网最快的应助速度,最高的求助完成率。 对每一个文献求助,科研通都将尽心尽力,给求助人一个满意的交代。
实时播报
漫才完成签到 ,获得积分10
1秒前
cxlhzq完成签到,获得积分10
1秒前
dan完成签到 ,获得积分10
1秒前
iris完成签到 ,获得积分10
2秒前
xiaoxiao完成签到 ,获得积分10
3秒前
SCIER完成签到,获得积分10
6秒前
panpanliumin完成签到,获得积分0
11秒前
世界和平完成签到 ,获得积分10
12秒前
xinjiasuki完成签到 ,获得积分10
17秒前
拙青完成签到,获得积分10
18秒前
海棠之秋完成签到,获得积分10
19秒前
21秒前
loren313完成签到,获得积分0
25秒前
我思故我在完成签到,获得积分10
26秒前
茶辞发布了新的文献求助10
27秒前
Shawn完成签到,获得积分10
28秒前
楼山柳完成签到 ,获得积分10
29秒前
Bella完成签到 ,获得积分10
30秒前
张再在完成签到 ,获得积分10
30秒前
33秒前
晨鸟发布了新的文献求助10
34秒前
完美世界应助lignin采纳,获得10
36秒前
危机的涫发布了新的文献求助10
37秒前
无极微光应助香蕉若南采纳,获得20
41秒前
一一完成签到 ,获得积分10
43秒前
黄淮科研小白龙完成签到 ,获得积分10
45秒前
47秒前
calphen完成签到 ,获得积分10
48秒前
NexusExplorer应助seekingalone采纳,获得10
48秒前
FashionBoy应助茶辞采纳,获得10
49秒前
许一朝完成签到 ,获得积分10
50秒前
lignin发布了新的文献求助10
53秒前
沉潜完成签到 ,获得积分10
54秒前
谛听不听完成签到 ,获得积分10
54秒前
亲亲小猴0816完成签到 ,获得积分10
55秒前
lignin完成签到,获得积分10
1分钟前
纯真保温杯完成签到 ,获得积分10
1分钟前
亚亚完成签到 ,获得积分10
1分钟前
cmuzxy完成签到,获得积分10
1分钟前
动听的飞松完成签到 ,获得积分10
1分钟前
高分求助中
(应助此贴封号)【重要!!请各用户(尤其是新用户)详细阅读】【科研通的精品贴汇总】 10000
Applied Min-Max Approach to Missile Guidance and Control 5000
Metallurgy at high pressures and high temperatures 2000
Inorganic Chemistry Eighth Edition 1200
Anionic polymerization of acenaphthylene: identification of impurity species formed as by-products 1000
The Psychological Quest for Meaning 800
Signals, Systems, and Signal Processing 610
热门求助领域 (近24小时)
化学 材料科学 医学 生物 纳米技术 工程类 有机化学 化学工程 生物化学 计算机科学 物理 内科学 复合材料 催化作用 物理化学 光电子学 电极 细胞生物学 基因 无机化学
热门帖子
关注 科研通微信公众号,转发送积分 6325937
求助须知:如何正确求助?哪些是违规求助? 8142015
关于积分的说明 17071730
捐赠科研通 5378411
什么是DOI,文献DOI怎么找? 2854190
邀请新用户注册赠送积分活动 1831847
关于科研通互助平台的介绍 1683076