操作語義學是計算機科學中的一個概念,它是使得計算機程序在數學上更加嚴謹的一種手段。其它類似的手段包括提供形式語義學,包括公理語義學和指稱語義。
一個計算機語言的操作語義描述一段合理的程序是怎樣被理解為一系列計算機步驟的。這些步驟就是這個程序的意義。在函數程式語言中一段終結性的序列在最後一步的返回程序的值。(由於一個程序可能是非非決定的,一般來說一個程序能夠有許多不同的計算步驟和許多不同的返回值。)
操作語義最早被用來定義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).