国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

F#中DSL原型設計:語法檢查和語義分析

原創
開發 后端
為了構建領域特定語言,你需要一個快速而有效的原型設計流程,它能夠對你的語言進行語法分析并執行語義檢查。本文將為大家介紹F#中DSL原型設計:語法檢查和語義分析。

【51CTO獨家特稿】最近,人們對于領域特定語言F#中DSL原型設計的興趣卷土重來。這些語言不僅能夠為特定領域提供更好等級的提煉,從而有助于減少在通用語言中因低等級構造而造成的錯誤;而且通過提供額外配置、定制的業務邏輯等,它們為用戶提供了一種有效的機制,用于細調你的應用程序。總之,DSL能夠讓你的應用程序更加多樣化并具有更好的伸縮性。51CTO向您推薦Visual Studio 2010中F#的一些資源

大致來講,領域特定語言的工作方式有兩種——你可以通過對以源DSL編寫的源文本進行轉譯來實施,或者通過將源文本編譯為可執行代碼。這兩種方式都有著獨特的優點和缺點。對于解釋器和編譯器的實施階段,很多都是類似的,甚至一模一樣;例如,語法和語義檢查在兩種方式中是共同的。在獲得合適的內部重現(inner representation)之后,編譯器實施包括幾個階段,逐步將這種重現分解為低等級的指令,生成匯編語言原生碼,或管理代碼(取決于目標平臺)。解釋器與之相反,很少執行這些階段。作為替代,你可以實施所謂的DSL 的“操作語義”(operational semantic);例如,為內部重現編寫一個評估器。

運行中的 Simply

圖1. 運行中的Simply

你可以在Simply上進行構建,來創建新的DSL并將其嵌入到你自己定制的開發外科中。此處演示的應用程序 SimplyLogo從零開始構建,F# 代碼少于500 行。

在本文介紹的F#中DSL原型設計,我們將為一個小型的DSL(由于其類似 C 語言的語法和簡潔,我將其稱為“Simply”)編寫一個解釋器,然后使用與Logo 那種語言類似的內置函數將其實例化。你可以通過在表達式語法器上來構建以完成實例化。之前我們已經在相關文章中進行講述,在這篇文章中,你可以看到活躍模式(active pattern)提供了一個***的機制(雖然付出了一點速度的小代價),能夠用于構建符合類型安全規則的語法器,它與用戶語法中的正規的 BNF 句法非常相似;并且能夠在增強的AST 重現上實施語言檢查(本文)和評估器(下一篇文章)。使用這種語言,你可以快速生成圖像,這些圖像能夠使用簡單的畫圖命令來定義——并且你可以在所有你需要的語境中使用這個核心評估器。在圖 1 中所示為該 DSL 的一種可能的嵌入。在本文中,我們主要關心的是構建 Simply 的語法器和檢查源程序以確認語法的正確性。

51CTO譯者注:為了學習這個系列的文章,你需要下載 F# May 2009 CTP 或Visual Studio 2010 Beta 1。

Simply 概述

Simply 是本文的DSL,它是一個具有靜態作用域、嵌套變量(nested variable)和函數聲明,以及簡單循環構造的小型編程語言。下面是一個很短的 Simply 程序:

  1. var x = 2   
  2. fun x(a b) { a + b + x }   
  3. fun x(y) { y + x(1 2) }   
  4. repeat 100 as i { x(i) } 

這段程序很容易讀懂,它包含四條命令,定義了一個變量、兩個函數和一個循環。為了分析這些命令的語法,你需要對上文中講述的語法器進行擴展。

對具有循環構造、變量和函數的Simply進行擴展

前文中實施的語法器使用函數調用對算術表達式進行語法分析并將其翻譯為定制的 AST 類型。對于 Simply,你需要一個稍微更為高級的內部重現來對表達式進行語法分析,這些表達式包含了簡單變量以及與其密切關聯的少量語言擴展,用于定義變量和函數,以及用簡單的循環構造(循環區塊)來表達循環。

如果你已經將AST 定義放在其自身模塊中,下面你可以看到新的擴展版本:

  1. namespace IntelliFactory.Simply   
  2. module Ast =  
  3.     type var = string   
  4.     type Expr =  
  5.  
  6.  | Number of float   
  7.  | BinOp of (float -> float -> float) * Expr * Expr  
  8.  | Var of var  
  9.  | FunApply of var * Expr list  
  10.  
  11.  static member Sum (e1, e2) = BinOp (( + ), e1, e2)  
  12.  static member Diff (e1, e2) = BinOp (( - ), e1, e2)  
  13.  static member Prod (e1, e2) = BinOp (( * ), e1, e2)  
  14.  static member Ratio (e1, e2) = BinOp (( / ), e1, e2) 

你可能已經注意到,我對這個模塊的代碼格式進行了細小的調整,以便符合 F# 編碼語法指南。我們的理想是用最少的代碼實現最多的功能,同時在需要增加代碼以及所表達的功能時仍然能夠進行快速建模(prototyping)并且修改最小化?,F在,你可以在代碼中添加 AST 增強,其指向不再是那些普通的算術表達式:

  1.    type Command =  
  2. | VarDef of var * Expr  
  3. | FunDef of var * var list * Command  
  4. | Repeat of Expr * var * Command  
  5. | Sequence of Command list  
  6. | Yield of Expr type Prog = Program of Command list 

這些F#中DSL原型設計的代碼定義了:

一個 Command 類型,可以對變量定義繼續編碼(利用一個值進行初始化) 函數定義(具有函數名稱、常規的參數列表和一個體現函數主體的 Command 值) 循環區塊(具有控制變量、循環程度表達式和一個用于體現循環區塊主體的 Command 變量) Command 排序(對于定義需多個簡單表達式的函數主體或循環區塊非常有用) 簡單表達式執行。一列這樣的表達構成了一個程序。利用這些類型,你現在可以擴展你支持創建的表達式語法器。為了更加方便,你可以再次使用 Listing 1 中代碼,然后對其進行稍微的增強:

這個核心語法器中唯一的更改(格式更改除外)位于(|Factor|_|)活躍模式在:這個版本添加了簡單的變量變量引用(第三條規則),以滿足增強的 AST 表達式語言中的相應的附加規則。

到這里,你就可以真正地開始加速,快速寫下 DSl 語法器的其余部分。首先添加關鍵字和特定字符的規則:

  1. let (|LBRACE|_|) s = "{" |> MatchSymbol s  
  2. let (|RBRACE|_|) s = "}" |> MatchSymbol s  
  3. let (|EQ|_|) s = "=" |> MatchSymbol s  
  4. let (|VAR|_|) s = "var" |> MatchSymbol s  
  5. let (|FUN|_|) s = "fun" |> MatchSymbol s  
  6. let (|REPEAT|_|) s = "repeat" |> MatchSymbol s  
  7. let (|AS|_|) s = "as" |> MatchSymbol s 

語法分析命令的規則是語法規則轉換為之前地定義的活躍模式的一種簡單的翻譯。

  1. let rec (|Command|_|) = function 
  2. | VAR (ID (v, EQ (Expression (expr, rest)))) 
  3. -> (Ast.Command.VarDef (v, expr), rest) 
  4. |> Some | FUN (ID (f, LPAREN (Star (|ID|_|) [] ( pars, RPAREN (Command (body, rest)))))) 
  5. -> (Ast.Command.FunDef (f, pars, body), rest)
  6.  |> Some | REPEAT (Expression (i, AS (ID (v, Command (body, rest))))) 
  7. -> (Ast.Command.Repeat (i, v, body), rest) 
  8. |> Some | LBRACE (Star (|Command|_|) [] (commands, RBRACE rest)) 
  9. -> (Ast.Command.Sequence commands, rest)
  10.  |> Some | Expression (e, rest) 
  11. -> (Ast.Command.Yield e, rest) |> Some | _ -> None 

例如,讓我們看看上面(|Command|_|)活躍模式中的***條規則。它字母的意思是:

“批評‘var’關鍵字,然后是標識符并將其與‘v’捆綁,然后是等于符號,然后是一個綁定到‘expr’的表達式;然后返回帶有變量及其初始值的 Command.VarDef 值,還有其余的輸入字符串,作為一個成功的匹配?!?/P>

其他規則一樣易于理解和構造。有一個細節需要進一步解釋,在函數定義或排序規則中如何使用(|Star|_|)活躍模式。記住,這是一個參數化(parameterized)的活躍模式,在它被應用到你再次匹配的值之前,它具有了兩個變量。***個變量是一個活躍模式,你可以“運行”零次或多次(名稱 Star,它反映了常規語言如 BNF 或常規表達式中的 star 操作符),第二變量是初始累加器,用于收集請求結果。由于該累加器的初始值通常是一個空列表,因此你可能會選擇以一種不需要初始值的方式重寫這個活躍模式;因此這就給了你一直更為緊湊的方式來指定“零次或多次”這種類型的規則。

***,你可以編寫定義了這個程序語法的規則:

  1. let (|Prog|_|) = function   
  2. | Star (|Command|_|) [] (commands, rest) -> (Ast.Prog.Program commands, rest)   
  3. |> Some | _ ->             None 

或者,編寫一個格式稍微有點冗長的規則:

  1.    let (|Prog|_|) s = match s with   
  2. | Star (|Command|_|) [] (commands, rest) -> (Ast.Prog.Program commands, rest)   
  3. |> Some | _ ->             None 

你可以在 Simply 程序上快速檢驗你的語法器——只需通過選取代碼并按 Alt+Enter 鍵將 AST 和語言模塊載入到 F# Interactive 中,然后測試一個 Simply 小程序:

  1. open Language " var x=1 var x=2 var x=3 fun foo(y)   
  2. { fun bar(foo) { var xx=x+1 foo+x } bar(y*2)   
  3. }   
  4. repeat 1000 as x { foo(x) }" |> (|Prog|_|) |> printf "Result=%A\n";;  
  5.  > Result=Some (Program [VarDef ("x",Number 1.0);   
  6. VarDef ("x",Number 2.0); VarDef ("x",Number 3.0);  
  7. FunDef ("foo",["y"], Sequence [FunDef ("bar",["foo"], Sequence [VarDef ("x",BinOp (,Var "x",Number 1.0));   
  8. Yield (BinOp (,Var "foo",Var "x"))]);   
  9. Yield (FunApply ("bar",[BinOp (,Var "y",Number 2.0)]))]);   
  10. Repeat (Number 1000.0,"x",Sequence [Yield (FunApply ("foo",[Var "x"]))])], "") > 

你將看到,對于送入到識別 Simply 程序的主活躍模式中這個程序,輸出結果是 AST 值的轉存。

F#中DSL原型設計:語法檢查和語義分析就到這里

原文標題:Prototyping DSLs in F#: Parsing and Semantic Checking

原文作者:Adam Granicz

【編輯推薦】

  1. F#入門:基本語法,模式匹配及List
  2. C# Actor的尷尬與F#美麗外表下的遺憾
  3. 函數式編程語言F#:基于CLR的另一個頭等編程語言
  4. Visual Studio 2010爆F#二進制兼容性問題
  5. 推薦Visual Studio 2010中F#的一些資源
責任編輯:彭凡 來源: 51CTO
相關推薦

2010-01-26 08:25:06

F#語法F#教程

2009-08-13 17:25:21

F#入門

2010-01-15 08:33:13

F#F#類型推斷F#教程

2010-03-26 19:22:08

F#代理

2010-01-07 10:04:18

F#函數式編程

2010-04-07 16:51:59

F#

2011-06-09 09:52:41

F#

2009-08-13 17:39:48

F#數據類型Discriminat

2009-08-19 09:42:34

F#并行排序算法

2010-07-05 10:08:52

Netstat TCP

2010-04-07 09:46:05

2009-09-10 14:18:59

Functional F#

2023-10-29 09:11:03

DSL語法

2009-12-14 09:04:10

F#運算符

2012-11-06 10:01:35

ContinuatioF#

2009-12-04 09:16:44

Visual Stud

2009-11-16 09:05:46

CodeTimer

2010-03-26 19:03:19

F#異步并行模式

2009-05-25 09:11:34

Visual StudF#微軟

2010-03-16 09:09:04

F#
點贊
收藏

51CTO技術棧公眾號

国产精品99久久99久久久| 97视频人免费观看| 亚洲狠狠婷婷| 国产精品成人在线| 亚洲色图视频免费播放| 亚洲警察之高压线| 在线成年人视频| 成人在线视频电影| 日韩欧美色综合网站| 久久99精品久久久久久国产越南 | 国产精品成人av在线| 亚洲视频中文字幕| 日本久久综合| 国产日韩欧美一区二区| 午夜不卡av在线| 国精品一区二区三区| 免费在线看黄色| 亚洲一卡二卡| 久久天天躁夜夜躁狠狠躁2022| 国产精品久久久久影院老司 | 超碰97人人人人人蜜桃| 日本精品视频一区二区| 老司机免费视频久久| 日韩免费va| 欧美精品性生活| 成人激情黄色网| 4438亚洲最大| 懂色av一区二区在线播放| 日韩一区免费| 99在线视频免费观看| 欧美裸体一区二区三区| 国产乱码精品一区二区三区av | 黄色在线观看www| 男人亚洲天堂网| 国产精品久久二区| 91精品久久久久久蜜臀| 成人国产亚洲欧美成人综合网| 夜夜春成人影院| 一色桃子av在线| 99视频精品免费| av一区二区在线看| 亚洲欧美一区二区三区在线| 中文字幕一区二区三区av| 亚洲第一se情网站| 秋霞在线观看一区二区三区| 久久精品视频中文字幕| 欧美日韩亚洲一区二区| 韩国女主播成人在线观看| 日韩aaa久久蜜桃av| 国产黄网站在线观看| 99福利在线观看| 国产激情美女久久久久久吹潮| 一色桃子一区二区| 欧美日韩午夜剧场| 成人综合在线观看| 一区二区在线| 青娱乐极品盛宴一区二区| 日本一级在线观看| 亚洲中文字幕无码av永久| 欧美亚洲视频在线观看| 久久亚洲风情| **精品中文字幕一区二区三区| 亚洲第一成年免费网站| 国自产拍偷拍精品啪啪一区二区| 久久综合色综合88| 日韩一区二区在线看| 欧美不卡在线视频| 亚洲毛片在线免费观看| 国内久久久精品| 亚洲自拍的二区三区| 日韩欧美高清在线| 国产精品国产三级国产aⅴ原创| 欧美午夜不卡| 亚洲一区二区电影| 国产中文字幕在线视频| 老太脱裤让老头玩ⅹxxxx| 91精品啪在线观看国产60岁| 懂色中文一区二区在线播放| 中文字幕一区二区三区欧美日韩| 热久久久久久| 特级毛片在线| 四虎影院在线播放| 中文字幕国产免费| 久久这里只有精品18| 欧美二区三区| 91在线观看欧美日韩| 国产+人+亚洲| 久久精彩免费视频| 日韩av资源在线播放| 欧美性受xxxx| 一区二区视频在线| 国产欧美视频一区二区| 成人午夜激情视频| 麻豆国产精品官网| 亚洲高清成人| 色呦哟—国产精品| 久久久久久久久久久久久久久久久久久| 蜜桃视频在线观看91| 国产成人欧美在线观看| 欧美老妇交乱视频| 国产一区二区三区在线观看视频| 欧美一二三四区在线| 在线免费观看一区| 亚洲成av人片在线观看| 亚洲日本一区二区| 国产精品视频一二| 久久久久久久国产精品影院| 懂色av一区二区三区蜜臀| 麻豆精品一区二区综合av| 乱码第一页成人| 欧美在线综合| 99国产精品私拍| 黄色另类av| 99久久精品费精品国产风间由美| 欧美成人基地| 高清一区二区视频| 国产精品裸体瑜伽视频| 超碰成人免费在线| a级黄色小视频| 麻豆tv在线播放| av女优在线播放| 丰满少妇久久久| 久在线观看视频| 91好吊色国产欧美日韩在线| 激情五月婷婷六月| 久久99久久99精品| 欧美国产亚洲一区| 国产精品免费入口| 国产a级一级片| 国产精品亚洲αv天堂无码| 北条麻妃在线观看| 日韩免费高清在线| 97视频在线| 麻豆国产精品视频| 在线国产精品播放| 黄色不卡一区| 国产精品白丝av嫩草影院| 亚洲视频三区| 国产精品视频一区视频二区| 24小时成人在线视频| 成人动态视频| 伊人久久大香线蕉无限次| 国内黄色精品| 香蕉视频官网在线观看日本一区二区| 91麻豆精品国产91久久久平台| 91一区二区三区四区| 欧美三级视频| 视频一区视频二区中文| 麻豆精品久久久| 成人晚上爱看视频| 国产精品天干天干在线综合| 亚洲一区二区视频在线观看| 日韩欧美中文免费| 成人在线视频首页| 国产精品爽爽爽| 成人网在线播放| 在线观看一区不卡| 人妻av中文系列| 在线观看成人免费视频| 日韩欧美a级成人黄色| 欧美性一二三区| 精品免费99久久| 中文字幕亚洲欧美日韩在线不卡 | 一区在线视频观看| 国产精品视频| 韩国av一区二区| 精品久久ai电影| 色综合久久综合中文综合网| 免费欧美视频| 成人黄色免费电影| 色视频www在线播放| 免费av网站在线观看| 欧美成人性网| 欧美精品中文| 午夜精品电影| 久久91精品久久久久久秒播| 久久色中文字幕| 亚洲国产精品欧美一二99| 欧美日韩精品三区| av中文字幕在线不卡| 欧美综合在线播放| 国产精品久久777777毛茸茸 | 羞羞视频在线观看欧美| 国产成a人亚洲精品| 国产欧美日本一区二区三区| 天天夜夜亚洲| 色播五月综合| 久久精品国产亚洲blacked| 亚洲第一福利在线观看| 日本韩国福利视频| 成年人网站91| 一级日韩一区在线观看| 美女网站视频久久| 国产精品av一区| www.66久久| 亚洲视频免费在线| 欧美性三三影院| 中文字幕av一区二区| 高清欧美性猛交xxxx| 国产精品一区二区三区在线观|