`

关于DSL(Domain Specification Language)的由来

 
阅读更多
      最近在学习Ruby的时候,看到Martin Fowler的文章有说,Ruby流行的一个很重要原因是它非常适合用来编写内部领域特定语言(Internal DSL),当时对DSL这个新鲜的名词非常不解,适逢公司有精于此道的大佛,万幸求得了一次非常有收获的Session,讲解了 何为DSL? DSL为什么会诞生?

1、知识漏斗(Knowledge Funnel)
人在学习一个新知识的时侯都会经历3个阶段,Mysterious(神秘);Heuristic(启发式);Algorithm(算法化)。以下逐步浅析:



Mysterious:在刚开始接触一类新的知识的时候,它对我们来说,非常神秘,似乎完全不知道其有何用武之地,这么打比方说吧,一个我们只打过一次照面的美女,除了知道此人美则以,其他一无所知,当然而更无从下手。

Heuristic:这个阶段,我们着重在深入了解新知识,通过不断涉猎跟它相关的东西,并尝试在实际环境中运用到,当然这中间少不了会遇到阻碍,碰上满鼻子灰,这个阶段的关键词是Trial,Error,就是不断的试错。好比真正展开对我们在第一阶段认识的美女的追求,各种各样的甜言蜜语,各种的romantic,然后各种的被拒绝。

Algorithm:此时已摸懂了这个知识的内在规律,能够把这个知识通过一个算法描述出来,只要输入A,那么一定能得到B。一旦我们把知识算法化之后,那么它就会给我们带来2大好处,Performance(效率,因为可以反复执行),Reliablity(可靠性,因为一切都可以由机器代劳,避免人为出错)。

     而这个知识漏斗客观体现出社会工作者的不同层次,对于一直处于Algorithm阶段的,即他永远只知道他知道的那部分知识,那么我们可以把他比作体力工作者。在高科技公司工作,并不代表你就不是体力工作者,关键看你做的事是程序化的,还是具有探索性质的。作为体力工作者,一旦在他们熟知的那些领域被人超过,其职业生涯就将面临巨大挑战。对于那些经常试错,学习新知识的工作者,可以称之为知识工作者,他们会通过一直沉降新的知识,让自己的综合能力不断提高,减少自己的无知程度。

2、无知的层次(Order of The Ignorance)
对于知识,我们可以分为3个层级,
第一层级:我们确切的掌握了我们知道的部分,这部分的知识是真正的被我们拥有的知识,其比例越重也就表示越博学。
第二层级:我们学会了我们不知道的部分,这部份的缺乏可以通过后天学习去补上,直至学会这个新的知识,然后将这个新的知识沉降到第一层级,从而成为我们拥有的知识。
第三层级:我们不了解我们不知道的部分,这部分的知识完全是因为没有这个意识要去学习他们,如果知识一直处于这个状态则是无法沉降成为我们拥有的知识。
      从上面的三个层级解释,可以看出,知识的获取就是一个沉降的过程,让没有意识到的知识变成我们需要学习的知识,再变成我们拥有的知识。比方说,我们通过扩大社交面,参加各种社区活动等去了解各领域的知识,扩大知识面也就扩大了我们需要学习的知识范围,就把一些没有意识到的第三层级的知识沉降到了第二层级,再通过学习,做Session等,把这部分知识逐步沉降到第一层级,变成自己的知识。

3、知识领域化
    知识有一个显著特征,它需要在蕴含它的环境才能被发现,也只能在蕴含它的环境被验证。比方说我们要知道金融业的知识,也只有从金融业角度去思维,并深入验证得出此知识领悟是否正确。

      说了这么久的知识,那么知识从何而来呢?具体知识大多来自于具体的业务领域(Business Domain),每个业务领域都有自己相关的业务知识。
      知识又存储在何处呢?通常概念下,我们的大脑,书,报刊等都是存储知识的媒介,在IT领域,我们主要的知识存储媒介就是软件。那么开发软件的过程就可以描述为把某领域相关的知识,进行沉降,得到一个Algorithm,然后通过软件相关技术把这个Algorithm化的知识封装到软件中的一个过程。
      通过从知识的角度重新定义了一下软件开发过程,那么如何做这个软件开发过程呢?我们是否可以用汇编来写一个Web程序,用Ruby来写一个电信软件平台呢?显然不会,大家在开发一个软件的时候,总会涉及到一个开发语言,开发工具的选择问题,软件开发完之后,我们还涉及到如何测试,选择什么样的工具来测试的问题,这一切的一切都和业务领域强相关。



      我们为什么不使用汇编来写一个Web程序呢?汇编能写一个Web应用吗?肯定是能的,我们不使用汇编的原因是因为我们有更好的选择,我们有更适合这个业务领域的工具供我们使用。
      在每个业务领域的知识中都会有一些基本的知识,对这个业务领域的所有业务都适用,当我们使用一些通用语言(c,c++,java...)把这些知识封装到开发工具(语言)中,让开发者能够更快速的开发这个业务领域的应用,这些开发工具(语言)就是DSL(特定领域语言),

   



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics