DSL(Domain Specific Language)介绍
前面介紹過模型驅動開發(MDD)、軟件工廠(Software factory)、特定領域建模 DSM(Domain Specific)等都是高抽象的開發方法,這些方法使用的語言都是特定領域語言(DSL)。相比于通用目的語言(C#/C++/JAVA/Delphi等)而言,DSL是一種為了特定任務而設計的開發語言,例如SQL是一種專門處理數據庫的語言,本篇將介紹一下DSL。
一種語言
我們熟知的編程語言(如C#、Ruby等)是一種通用語言,MDA基于UML語言,而模型驅動開發(MDD)基于DSL。DSL是一種基于特定領域的語言,它使工作更貼近于客戶的理解,而不是實現本身,這樣有利于開發過程中,所有參與人員使用同一種語言進行交流。
DSML
DSML是 特定領域模型語言(domain-specific modelling language),之前介紹的MetaEdit+使用的DSM方法中使用的就是DSML,它是一種可以用來構建圖形模型的一種DSL,DSM的GOPPRR就是一個用來構建DSML語言的元模型。
DSL涉及內容
- 問題域、問題空間
- 語法、語義
- 案例、方法、工具
DSL架構
- DSL腳本(DSL Script):每一個DSL的核心都是一個域模型,它定義了這一語言所代表的各種概念,這些概念的屬性,以及它們之間的關系
- 在問題域中用于構建、配置或者其他用途的一種語言
- 可以是文本,也可以是圖形,或者兩者混合使用
- ?圖形語言不只是圖表,否則使用Visio之類的畫圖軟件就行了,它實際上是要創建模型,這個模型要能夠從概念上描繪你正在創建的系統,并對其內容進行圖表化的表示。一個模型可以同時由多個圖表來表示,每個圖表表示模型的某個方面
- ?文本語言用戶輸入,可以快速的打字。
- ?文本語言的優勢在于可以進行比較和合并,而圖形表達式可以更容易的看出內容之間的關聯。
- ?相對來說,文本語言比圖形復雜
- 語義模型(Semantic Model)
- DSL腳本的一種內存完整表示
- 有時候這個就是抽象語法樹(AST)
- 分離Parse和Generate
- 生成代碼(Generated Code):DSL的一個最重要的應用是用來生產簡單的文本形式的工件,例如源代碼、數據庫腳本
- DSL腳本的一種可執行表示
- 解釋語義模型
DSL應用的優點
樣式(Styles)
之前在信息系統開發平臺OpenExpressApp:【OpenTest】 之 如何實現自動化測試框架介紹了在OEA上使用Ruby語法實現的一個自動化測試語言,這個就屬于內部DSL。而在OpenExpressApp對建模支持的初步計劃中介紹的MetaModelEngie屬于外部DSL。
外部DSL可以擺脫內部DSL寄宿語言的限制,可以重新設計一種新的語言,但是增加了學習新的語言的學習成本,并且需要工具的支持。
設計DSL
為了降低風險,我們并不是馬上就從頭開始開發框架及其DSL,而是應該從現有的可以在某些應用中使用的代碼開始,逐步的對其進行參數化,逐步的發現那些在不同應用中變化的部分,然后使這些部分依賴于DSL。
自上而下的方法傾向于快速建立一個完整且自包含的模型,具有更長遠的考慮,有助于保證結構的一致性。但是從另一方面看,這種方法容易導致在概念層設計出很復雜的模型,并且該模型難于實現。因此在實際應用中,將自上而下和自下而上兩種方法交替使用會更有效。采用漸進的方式可以避免早期投入過大風險,但是需要定期進行一致性檢查。
在《Visual Studio DSL工具特定領域開發指南》書中對設計DSL做了如下步驟:
應用場景
? ......
書籍
Martin Fowler花了幾年時間寫了一本DSL的書籍《Domain Specific Languages》,我還沒有看,感興趣的可以先看看它在網站上寫的系列文章 Domain Specific Languages
?
Best Practices for DSLs and Model-Driven Development?
讀書筆記:Visual Studio DSL工具特定領域開發指南
DSL的演進
轉載于:https://blog.51cto.com/zhoujg/403112
總結
以上是生活随笔為你收集整理的DSL(Domain Specific Language)介绍的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: silverlight开发无法调试问题
- 下一篇: 打印机共享无法正常打印的处理思路