热门问题
时间线
聊天
视角
串接式編程語言
来自维基百科,自由的百科全书
Remove ads
串接式(concatenative)編程語言,是無點的計算機編程語言,在其中所有表達式都指示為函數,而表達式的並列指示函數複合[1]。串接式編程語言將常見於其他編程樣式中的函數應用,替代為函數複合,作為建造子例程的缺省方法。
名稱含義
串接式語言這個名詞,最早在2001年提出的Joy語言中採用。在這門語言中,符號的串接的語法關係,被直接映射成函數的複合的語義關係上:「兩個程序的串接指示這兩個程序指示的函數的複合」[2]。
例子
例如,在如下的應用式語言的運算操作序列:
y = foo(x)
z = bar(y)
w = baz(z)
在串接式語言中被寫為沒有參數的函數的序列[3]:
foo bar baz
在串接式語言中的函數和過程,不是值級別而是函數級的,就是說它們典型的不通過顯式的名字或標識符,來表示出它們所操作的數據結構;轉而在它們中,函數被定義為管道,它的一序列操作運算,從一個隱式數據結構上取得參數,所有函數都在其上操作,並將函數的結果返回到這個共享的數據結構,從而被下一個算子(operator)所用[4]。
複合式語義與鏡像這種語義的語法相組合,使得串接式語言高度服從於程序的代數式操縱[5];儘管在其中直接書寫數學表達式可能會有困難[6]。串接式語言可以通過堆棧機器以高效的方式實現,並以虛擬機及其指令集的形式含蓄的出現[6]。
Remove ads
特性
串接式語言的特性來自它們的複合式語法和語義:
實現
第一個串接式編程語言是Forth,但是第一個自稱串接式語言的是Joy。其他串接式語言有Factor、Onyx、PostScript和RPL等。
多數現存的串接式語言是基於堆棧的;這不是必須要求,並已有其他模型提出[10][11][12]。串接式語言目前作為目標語言用於嵌入式系統、桌面和網頁編程,還用於研究用途。
參見
引用
外部連結
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads