领域特定语言是在特定领域下用于特定上下文的语言。作为开发者,很有必要了解领域特定语言的含义,以及为什么要使用特定领域语言。

领域特定语言 domain-specific language (DSL)是一种旨在特定领域下的上下文的语言。这里的领域是指某种商业上的(例如银行业、保险业等)上下文,也可以指某种应用程序的(例如 Web 应用、数据库等)上下文。与之相比的另一个概念是 通用语言 general-purpose language (GPL,LCTT 译注:注意不要和 GPL 许可证混淆),通用语言则可以广泛应用于各种商业或应用问题当中。

DSL 并不具备很强的普适性,它是仅为某个适用的领域而设计的,但它也足以用于表示这个领域中的问题以及构建对应的解决方案。HTML 是 DSL 的一个典型,它是在 Web 应用上使用的语言,尽管 HTML 无法进行数字运算,但也不影响它在这方面的广泛应用。

而 GPL 则没有特定针对的领域,这种语言的设计者不可能知道这种语言会在什么领域被使用,更不清楚用户打算解决的问题是什么,因此 GPL 会被设计成可用于解决任何一种问题、适合任何一种业务、满足任何一种需求。例如 Java 就属于 GPL,它可以在 PC 或移动设备上运行,嵌入到银行、金融、保险、制造业等各种行业的应用中去。

DSL 的类别

从使用方式的角度,语言可以划分出以下两类:

  1. DSL:使用 DSL 形式编写或表示的语言
  2. 宿主语言 host language :用于执行或处理 DSL 的语言

由不同的语言编写并由另一种宿主语言处理的 DSL 被称为 外部 external DSL。

以下就是可以在宿主语言中处理的 SQL 形式的 DSL:

SELECT account
FROM accounts
WHERE account = '123' AND branch = 'abc' AND amount >= 1000

因此,只要在规定了词汇和语法的情况下,DSL 也可以直接使用英语来编写,并使用诸如 ANTLR 这样的 解析器生成器 parser generator 以另一种宿主语言来处理 DSL:

if smokes then increase premium by10%

如果 DSL 和宿主语言是同一种语言,这种 DSL 称为 内部 internal DSL,其中 DSL 由以同一种语义的宿主语言编写和处理,因此又称为 嵌入式 embedded DSL。以下是两个例子:

Bash 形式的 DSL 可以由 Bash 解释器执行:

if today_is_christmas; then apply_christmas_discount; fi

同时这也是一段看起来符合英语语法的 Bash。

使用类似 Java 语法编写的 DSL:

orderValue = orderValue.applyFestivalDiscount().applyCustomerLoyalityDiscount().applyCustomerAgeDiscount();

这一段的可读性也相当强。

实际上,DSL 和 GPL 之间并没有非常明确的界限。

DSL 家族

以下这些语言都可以作为 DSL 使用:

  1. Web 应用:HTML
  2. Shell:用于类 Unix 系统的 sh、Bash、CSH 等;用于 Windows 系统的 MS-DOS、Windows Terminal、PowerShell 等
  3. 标记语言:XML
  4. 建模:UML
  5. 数据处理:SQL 及其变体
  6. 业务规则管理:Drools
  7. 硬件:Verilog、VHD
  8. 构建工具:Maven、Gradle
  9. 数值计算和模拟:MATLAB(商业)、GNU Octave、Scilab
  10. 解析器和生成器:Lex、YACC、GNU Bison、ANTLR

为什么要使用 DSL?

DSL 的目的是在某个领域中记录一些需求和行为,在某些方面(例如金融商品交易)中,DSL 的适用场景可能更加狭窄。业务团队和技术团队能通过 DSL 有效地协同工作,因此 DSL 除了在业务用途上有所发挥,还可以让设计人员和开发人员用于设计和开发应用程序。

DSL 还可以用于生成一些用于解决特定问题的代码,但生成代码并不是 DSL 的重点并不在此,而是对专业领域知识的结合。当然,代码生成在领域工程中是一个巨大的优势。

DSL 的优点和缺点

DSL 的优点是,它对于领域的特征捕捉得非常好,同时它不像 GPL 那样包罗万有,学习和使用起来相对比较简单。因此,它在专业人员之间、专业人员和开发人员之间都提供了一个沟通的桥梁。

而 DSL 最显著的缺点就在于它只能用于一个特定的领域和目标。尽管学习起来不算太难,但学习成本仍然存在。如果使用到 DSL 相关的工具,即使对工作效率有所提升,但开发或配置这些工具也会增加一定的工作负担。另外,如果要设计一款 DSL,设计者必须具备专业领域知识和语言开发知识,而同时具备这两种知识的人却少之又少。

DSL 相关软件

开源的 DSL 软件包括:

  1. Xtext:Xtext 可以与 Eclipse 集成,并支持 DSL 开发。它能够实现代码生成,因此一些开源和商业产品都用它来提供特定的功能。用于农业活动建模分析的 多用途农业数据系统 Multipurpose Agricultural Data System (MADS)就是基于 Xtext 实现的一个项目,可惜的是这个项目现在已经不太活跃了。
  2. JetBrains MPS:JetBrains MPS 是一个可供开发 DSL 的 集成开发环境 Integrated Development Environment ,它将文档在底层存储为一个抽象树结构(Microsoft Word 也使用了这一概念),因此它也自称为一个 投影编辑器 projectional editor 。JetBrains MPS 支持 Java、C、JavaScript 和 XML 的代码生成。

DSL 的最佳实践

如果你想使用 DSL,记住以下几点:

  1. DSL 不同于 GPL,DSL 只能用于解决特定领域中有限范围内的问题。
  2. 不必动辄建立自己的 DSL,可以首先尝试寻找已有的 DSL。例如 DSLFIN 这个网站就提供了很多金融方面的 DSL。在实在找不到合适的 DSL 的情况下,才需要建立自己的 DSL。
  3. DSL 最好像平常的语言一样具有可读性。
  4. 尽管代码生成不是一项必需的工作,但它确实会大大提高工作效率。
  5. 虽然 DSL 被称为语言,但 DSL 不需要像 GPL 一样可以被执行,可执行性并不是 DSL 需要达到的目的。
  6. DSL 可以使用文本编辑器编写,但专门的 DSL 编辑器可以更轻松地完成 DSL 的语法和语义检查。

开发者需要了解的领域特定语言(DSL)相关推荐

  1. 【转】开发者需要了解的领域特定语言(DSL)

    转自:开发者需要了解的领域特定语言(DSL) - 知乎 领域特定语言是在特定领域下用于特定上下文的语言.作为开发者,很有必要了解领域特定语言的含义,以及为什么要使用特定领域语言. 领域特定语言doma ...

  2. 【Kotlin】Kotlin 领域特定语言 DSL 原理 二 ( 中缀表达式 )

    文章目录 I . 中缀表达式 ( 中缀调用 ) II . 中缀表达式 ( 中缀调用 ) 示例代码 I . 中缀表达式 ( 中缀调用 ) 1 . 中缀表达式作用 : 中缀表达式是 Kotlin 领域特定 ...

  3. 【Kotlin】Kotlin 领域特定语言 DSL 原理 一 ( DSL 简介 | 函数 / 属性扩展 )

    文章目录 I . DSL 简介 II . Kotlin 函数扩展 III . Kotlin 属性扩展 I . DSL 简介 1 . DSL ( Domain Specific Language ) 领 ...

  4. 在Visual Studio 2012中使用VMSDK开发领域特定语言(二)

    本文为<在Visual Studio 2012中使用VMSDK开发领域特定语言>专题文章的第二部分,在这部分内容中,将以实际应用为例,介绍开发DSL的主要步骤,包括设计.定制.调试.发布以 ...

  5. 在Visual Studio 2012中使用VMSDK开发领域特定语言(一)

    前言 本专题主要介绍在Visual Studio 2012中使用Visualization & Modeling SDK进行领域特定语言(DSL)的开发,包括两个部分的内容.在第一部分中,将对 ...

  6. 走近“领域特定语言”(Domain-Specific Languages)

    领域特定语言(Domain-Specific Languages,简称DSL),是一个很有用的术语和概念,但其边界很模糊.一些东西很明显是DSL,但另一些可能会引发争议.本文接下来就走近"领 ...

  7. 走近“领域特定语言”

    文/Martin Fowler 领域特定语言(Domain-Specific Languages,简称DSL),是一个很有用的术语和概念,但其边界很模糊.一些东西很明显是DSL,但另一些可能会引发争议 ...

  8. DSL 领域特定语言

    一.DSL介绍 DSL(Domain Specific Language)是针对某一领域,具有受限表达性的一种计算机程序设计语言. 常用于聚焦指定的领域或问题,这就要求 DSL 具备强大的表现力,同时 ...

  9. 如何设计一门语言(十)——正则表达式与领域特定语言(DSL)

    几个月前就一直有博友关心DSL的问题,于是我想一想,我在gac.codeplex.com里面也创建了一些DSL,于是今天就来说一说这个事情. 创建DSL恐怕是很多人第一次设计一门语言的经历,很少有人一 ...

最新文章

  1. 边缘计算 — 边缘网络
  2. 【机器学习基础】常见二分类损失函数、距离度量的Python实现
  3. hive底层原理 sql执行过程_hive sql编译过程
  4. tornado上传图片
  5. caffe学习(1) ubunu 16.04+caffe+cuda8.0+opencv3.1安装
  6. 第一个Django应用程序_part1
  7. oracle 测试试题,oracle试题
  8. 学习knex过程中好的参考资料整理
  9. 双目立体视觉匹配算法-----SAD匹配算法、BM算法、SGBM算法、GC算法
  10. git pull提示remote error:CAPTCHA required
  11. python 电脑文件变动提醒_Python整理文件方法,效率提升100倍-docx是什么文件
  12. C++面向对象编程之类的使用(基础案例学习)
  13. Freeswitch与外域IP对接之incoming call
  14. DevOps定义基础入门及历史
  15. 最最超级无敌的冷笑话,能把人噎死
  16. 交换机组播风暴_cisco 交换机端口广播风暴设置(非常详细)
  17. 金蝶新建生产领料单,单据编号不能自动填写
  18. cat全链路监控_全链路监控选型
  19. Wireshark分析网络慢
  20. 粉笔公考——判断推理

热门文章

  1. 中医药matlab,MATLAB在医学图像增强中的应用
  2. 华为ct5000瘦客户机_第八集[达特分享]华为CT5000一键刷BIOS安装OpenWRT制作软路由...
  3. java匿名内部类返回值_java匿名内部类
  4. 整理总结:深入浅出统计学——正态分布的运用
  5. 中国贫富标准,你是哪个级?
  6. 名帖149 陆启成 楷书《陈眉公小窗幽记》
  7. 细胞自动机 二维数组的使用
  8. java如何键盘输入文本,用Java语言从键盘中输入内容
  9. easyExcel实现动态表头的数据导出,合并单元格,列宽策略
  10. vs2010安装后找不到运行程序