成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Lua的語法是無歧義的嗎?

開發 前端
Lua5.0的語法非常簡潔,這從參考手冊中的語法定義的規模(轉換成標準BNF形式大概有100個左右的產生 式)可以看出。

Lua5.0的語法非常簡潔,這從參考手冊中的語法定義的規模(轉換成標準BNF形式大概有100個左右的產生 式)可以看出。不過簡潔歸簡潔,它卻不完全是無二義性的。下面將用具體例子揭示什么樣的代碼會引起歧義(執行環境是www.lua.org發布的 Lua5.04)。

首先定義如下幾個函數:

  1. function foo(a) 
  2. print("foo print",a) 
  3. return a 
  4. end 
  5. function goo(a) 
  6. print("goo print",a) 
  7. return a 
  8. end 
  9. function hoo(a) 
  10. print("hoo print",a) 
  11. return a 
  12. end 

試看這一段代碼:

foo(goo)

(hoo)(1979)

如果試圖編譯執行上面這段程序,那么解釋器就會報告 "ambiguous syntax (function call x new statement) near '(' " 這樣的錯誤。為什么呢?或許寫程序的人原本的意思就是***行foo(goo)為一個單獨的函數調用語句(statement),而第二行(hoo) (1979)又為另一個單獨的函數調用語句(Lua中語句之間的分隔符——分號并非必需,而是可選的)。但是不要忘記了foo(goo)(hoo)是一個 語法上完全合法的函數調用形式(在編譯過程中換行符作為空白符會被忽略掉),foo(goo)(hoo)(1979)也可以成為一個完整的函數調用語句。 這樣的話,編譯器就無法知道程序員的真正意圖了。

我們可以再深入到編譯過程里頭一點看看。Lua語法的形式定義(轉換成BNF標準形式)包含如下幾個產生式:

(1) stat -> functioncall (語句的產生式)

(2) prefixexp -> functioncall (前綴表達式的產生式)

(3) functioncall -> prefixexp args

| prefixexp ':' Name args (函數調用的產生式)

可以發現,functioncall既可以被規約(reduce)為stat,也可以被規約成prefixexp,(1)和(2)兩個產生式發生了沖突,編譯器不知道用哪一個對foo(goo)進行規約,所以便出現了錯誤。

其實要解決這個問題歧義問題也很簡單,在***行后面加一個語句分隔符——分號,編譯器就會把代碼編譯成兩個獨立的語句?;蛘甙褍尚泻喜⒊梢恍?, 那么foo(goo)(hoo)(1979)就被看作是一個完整的函數調用(其實此時仍然是有歧義的,但是Lua5.04通過優先選擇prefixexp -> functioncall進行規約解決了二義性)。

實際上,還有另外3種情況也會引起歧義:

  1. -- prefixexp -> functioncall 與   
  2. -- exp -> functioncall 沖突。   
  3. -- 編譯器不知道該把foo(goo)解釋成表達式(exp)還是前綴表達式   
  4. local v = foo(goo)   (hoo)(1979)   
  5. -- exp -> var 與 prefixexp -> var 沖突   
  6. -- 第二行的變量(var)m不知道該被看成表達式還是前綴表達式   
  7. m = foo   local v = m   (goo)(1979)   
  8. -- prefixexp -> '(' exp ')' 與   
  9. -- exp -> '(' exp ')' 沖突   
  10. -- 不知道該把(t.fn)看成表達式還是前綴表達式   
  11. t = {fn = foo}   local v = (t.fn)   (goo)(1979) 

***個例子中解決歧義的兩種方法同樣也適用于這三種情況。至此我們不難發現,引起歧義的根本原因在于Lua語句之間的分隔符是可選而不是必需的。如果強制 要求象C語言那樣每條語句后跟一個分號,那么二義性就不復存在(這一點在本文作者構造Lua5.0的SLR解析表時得到了驗證)。但是有許多人未必喜歡敲 入那么多討厭的分號,所以Lua的作者把選擇的權利留給了程序員自己,付出的代價就是引進了這些模糊的代碼(雖然出現的幾率不大),這也算是語言設計時的 一種折衷吧。

原文鏈接:http://tech.it168.com/j/2008-02-17/200802171001717.shtml

責任編輯:陳四芳 來源: it168.com
相關推薦

2024-03-28 09:26:23

無服務數據庫趨勢

2023-10-08 13:13:00

無代碼編程

2018-01-05 14:08:08

無服務器化云計算云遷移

2020-07-01 07:00:00

軟件開發低代碼無代碼

2009-11-12 10:55:17

Lambda表達式

2011-08-29 15:49:21

Lua語法

2021-05-27 10:12:11

Java無服務器化開發

2024-08-05 01:28:26

2023-02-02 11:53:44

nolock關鍵詞SQLserver

2012-07-25 22:15:00

Nginxlua

2023-01-30 09:01:34

DecoratorsJS語法

2017-01-10 09:48:58

PHP語言Perl

2022-01-10 07:27:04

DataOps數據驅動

2011-05-31 09:38:48

OracleDUAL

2018-07-27 14:17:32

2011-11-10 14:21:48

Java

2022-11-22 08:01:30

2011-08-25 16:20:33

Lua腳本變量

2014-09-19 10:46:36

LuaCC++

2024-02-26 11:03:05

golang緩存數據庫
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品96久久久久久 | 国产精品亚洲成在人线 | 国产一区二区在线看 | 一级做a爰片性色毛片16美国 | 一区二区在线 | 久久人人国产 | 91精品在线看 | 中文字幕人成乱码在线观看 | 国产高清一区二区三区 | 国产精品一区二区三 | 男女又爽又黄视频 | 综合自拍 | 亚洲精品一区中文字幕乱码 | 久久久片 | 久久久久国产一区二区三区 | 欧美黄色片 | 天堂久久网 | 国产一区二区在线播放 | 亚洲成av人影片在线观看 | 亚洲中国字幕 | 久久日韩精品一区二区三区 | 精品免费国产一区二区三区四区 | 久久av综合| 国产在线一区二区三区 | 日韩免费高清视频 | 国产精品亚洲一区二区三区在线 | 日韩精品视频在线 | 午夜看看| 亚洲精品一区二区三区中文字幕 | 国产视频二区在线观看 | 欧美jizzhd精品欧美巨大免费 | 精品国产乱码久久久久久88av | 97超碰成人| 黄色国产在线播放 | 91天堂网| 一级黄色片在线免费观看 | 久久久久久久久久久福利观看 | 欧美日本在线观看 | 中文字幕亚洲一区 | 欧美日韩久 | 亚洲成人久久久 |