操作语义学是计算机科学中的一个概念,它是使得计算机程序在数学上更加严谨的一种手段。其它类似的手段包括提供形式语义学,包括公理语义学和指称语义。
一个计算机语言的操作语义描述一段合理的程序是怎样被理解为一系列计算机步骤的。这些步骤就是这个程序的意义。在函数编程语言中一段终结性的序列在最后一步的返回程序的值。(由于一个程序可能是非非决定的,一般来说一个程序能够有许多不同的计算步骤和许多不同的返回值。)
操作语义最早被用来定义Algol 68的语义。下面这句话引用修正的ALGOL 68报告:
一个使用严格语言编写的程序的意义是通过一个假设的计算机来执行该程序的组成部分时完成的行动来解释的。(Algol68,第二章)
丹纳·司科特是第一个在今天的这个定义下使用操作语义这个概念的(Plotkin04b)。以下是司科特关于形式语义学的讲稿,其中他提到了语义的“操作”观点。
把目光注意使得语义在更‘抽象’和更‘清晰’可以,但是假如把操作方面完全忽略的话这个计划毫无用处。(Scott70)
结构操作语义
戈登·普罗特金(Gordon Plotkin)在(Plotkin04a)中引入了结构操作语义的概念作为一个定义操作语义的逻辑方式。其基本主意是使用程序组成部分的行为来定义一个程序的行为,由此来提供一个对操作语义结构性的,即按照句法和归纳性的,分析。结构操作语义对一个程序的行为的说明是通过一(组)变化关系来表示的。其形式是一系列推理规则,这些推理规则通过一组句法的转换来定义该组的合理转换。
比如我们考虑一个简单计算机语言的部分语义,在Plotkin04a和Hennessy90以及其它教科书中有相应的图像。设为该语言的程序域,是状态域(即函数的存储地址及值)。假如我们有表述(的域)、值()和存储地址(),则一个存储更新指令的语义为:
使用普通语言,这个公式说假如在状态的的值为则程序会通过更新的状态。
系列的语义可以用下列规则来表达:
第一个规则说假如处于状态的程序可以被简化为处于状态的程序的话则处于状态的程序能被简化为处于状态的程序。第二个规则说假如处于状态的程序以状态结束的话,则处于状态的程序可以简化为处于状态的程序。这里的语义是结构化的,因为程序序列的意义是由的意义和的意义定义的。
假如我们还有状态的布尔函数表示的话我们可以定义while指令的语义:
这样的定义允许对程序行为进行公式化的分析和研究程序间的关系。
由于结构操作语义看上去非常易懂,结构简单,因此它获得了很大的欢迎,实际上成为定义操作语义的标准。结构操作语义最初的报告因此获得了约900次引用[1],成为计算机科学中被引用最多的技术报告之一。
参考资料
- Adriaan van Wijngaarden等,《Revised Report on the Algorithmic Language ALGOL 68》,IFIP,1968年([1][永久失效链接])
- Gordon D. Plotkin,《The Origins of Structural Operational Semantics》,JALP,60-61:3-15, 2004年(preprint (页面存档备份,存于互联网档案馆))
- Dana S. Scott,《Outline of a Mathematical Theory of Computation, Programming Research Group, Technical Monograph PRG–2》,牛津大学,1970年
- Gordon D. Plotkin,A Structural Approach to Operational Semantics (页面存档备份,存于互联网档案馆),(1981年),Tech. Rep. DAIMI FN-19, Computer Science Department, Aarhus University, Aarhus, Denmark. Reprinted with corrections in J. Log. Algebr. Program. 60-61: 17-139(2004年)(preprint (页面存档备份,存于互联网档案馆)).
- Matthew Hennessy,《Semantics of Programming Languages》. Wiley, 1990年. 网上.
- ^ 存档副本. [2009-03-06]. (原始内容存档于2007-03-14).