新聞中心

EEPW首頁(yè) > 牛人業(yè)話(huà) > 編程語(yǔ)言的發(fā)展趨勢(shì)及未來(lái)方向(5):元編程

編程語(yǔ)言的發(fā)展趨勢(shì)及未來(lái)方向(5):元編程

作者: 時(shí)間:2017-04-12 來(lái)源:網(wǎng)絡(luò) 收藏

  這是Anders Hejlsberg(不用介紹這是誰(shuí)了吧)在比利時(shí)TechDays 2010所做的開(kāi)場(chǎng)演講。由于最近我在博客上關(guān)于語(yǔ)言的討論比較多,出于應(yīng)景,也打算將Anders的演講完整地聽(tīng)寫(xiě)出來(lái)。在上一部分中,Anders談及了他眼中的另一個(gè)發(fā)展趨勢(shì):動(dòng)態(tài)性。在這一部分中,Anders則討論了動(dòng)態(tài)語(yǔ)言所擅長(zhǎng)的“”,并簡(jiǎn)單介紹了他為靜態(tài)類(lèi)型語(yǔ)言所設(shè)計(jì)的一種改進(jìn)方案:編譯器即服務(wù)。

本文引用地址:http://2s4d.com/article/201704/346501.htm

  如果沒(méi)有特別說(shuō)明,所有的文字都直接翻譯自Anders的演講,并使用我自己的口語(yǔ)習(xí)慣表達(dá)出來(lái),對(duì)于Anders的口誤及反復(fù)等情況,必要時(shí)在譯文中自然也會(huì)進(jìn)行忽略。為了方便理解,我也會(huì)將視頻中關(guān)鍵部分進(jìn)行截圖,而某些代碼演示則會(huì)直接作為文章內(nèi)容發(fā)表。

  (聽(tīng)寫(xiě)開(kāi)始,接上篇)

    

 

  動(dòng)態(tài)語(yǔ)言的另一個(gè)關(guān)鍵和有趣之處在于“”?!?a class="contentlabel" href="http://2s4d.com/news/listbylabel/label/元編程">元編程”實(shí)際上是“代碼生成”的一種別稱(chēng),其實(shí)在日常應(yīng)用中我們也經(jīng)常依賴(lài)這種做法。觀察動(dòng)態(tài)語(yǔ)言適合元編程的原因也是件十分有趣的事情。

  在這個(gè)藍(lán)框中是一段Ruby on Rails代碼(見(jiàn)上圖)。簡(jiǎn)單地說(shuō),這里定義了一個(gè)Order類(lèi),繼承了ActiveRecord,也定義了一些關(guān)系,如belongs_to和has_many關(guān)系。Ruby這種動(dòng)態(tài)語(yǔ)言的關(guān)鍵之處,在于一切事物都是通過(guò)執(zhí)行而得到的,包括類(lèi)型聲明。比如這里的類(lèi)型申明執(zhí)行了belongs_to和has_many方法的調(diào)用,執(zhí)行belongs_to會(huì)截獲一對(duì)多或一對(duì)一關(guān)系所需要的信息,因此在這里語(yǔ)言是在運(yùn)行的時(shí)候,動(dòng)態(tài)為自身生成了代碼。

  實(shí)現(xiàn)這點(diǎn)在動(dòng)態(tài)語(yǔ)言里自然會(huì)更容易一些,因?yàn)樗鼈儧](méi)有編譯期和執(zhí)行期的區(qū)別。靜態(tài)類(lèi)型語(yǔ)言在這方面會(huì)比較困難。例如在C#或Java里使用ORM時(shí),傳統(tǒng)的做法是讓代碼生成器去觀察數(shù)據(jù)庫(kù),生成一大堆代碼,然后再編譯,有些復(fù)雜。不過(guò)我時(shí)常想著去改善這一點(diǎn)。

    

 

  其中一種做法,是我們正在努力實(shí)現(xiàn)的“編譯器即服務(wù)”,我現(xiàn)在先對(duì)它進(jìn)行一些簡(jiǎn)單的介紹。傳統(tǒng)的編譯器像是一個(gè)黑盒,你在一端輸入代碼,而另一端便會(huì)生成.NET程序集或是對(duì)象代碼等等。而這個(gè)黑盒卻很神秘,你目前很難參與或理解它的工作。

  你可以想象,一些代碼往往是不包含在源文件中的。如果你想要交互式編程的體驗(yàn),例如一個(gè)交互式的提示符,那么代碼不是保存在源文件中而是由用戶(hù)輸入的。如果您在實(shí)現(xiàn)一個(gè)DSL,例如Windows Workflow或是Biztalk,則可能用C#或VB實(shí)現(xiàn)了一些需要?jiǎng)討B(tài)執(zhí)行的規(guī)則,它們也不是保存在源文件中,而可能是放在XML屬性中的。此時(shí)你想編譯它們卻做不到,你還是要把它們放入源文件,這就變的復(fù)雜了。

    

 

  另一方面,對(duì)于編譯器來(lái)說(shuō),我們不一定需要它生成程序集,有時(shí)候需要的是一些樹(shù)狀的表現(xiàn)形式。例如一些由用戶(hù)反射生成的代碼,便可能不要程序集而是一個(gè)解析樹(shù),然后可以對(duì)它進(jìn)行識(shí)別和重寫(xiě)。因此,我們可能越來(lái)越需要的是一些API,以此開(kāi)放編譯器的功能。

  例如,你可以給它一小段代碼,讓它返回一段可執(zhí)行的程序,或是一個(gè)可以識(shí)別或重寫(xiě)的解析樹(shù)。這么做可以讓靜態(tài)類(lèi)型語(yǔ)言獲得許多有用的功能,例如元編程,以及可操作的完整的對(duì)象模型等等。我們正在朝這方面努力,我也會(huì)在下午1點(diǎn)的C# 4.0演講中談?wù)摳噙@方面的內(nèi)容。



關(guān)鍵詞: 編程語(yǔ)言 元編程

評(píng)論


相關(guān)推薦

技術(shù)專(zhuān)區(qū)

關(guān)閉