讀自:The Definitive ANTLR 4 Reference, 2nd Edition.pdf
1、文法一
<b>Hello.g4 </b>
grammar Hello;// Define a grammar called Hello
r : 'hello' ID ; // match keyword hello followed by an identifier
ID : [a-z]+ ;// match lower-case identifiers
WS : [ \t\r\n]+ -> skip ; // skip spaces, tabs, newlines, \r (Windows)
2、詞法解析一
<b>解析語句一:hello parrt ctrl+D</b>
[@0,0:4='hello',<1>,1:0]
[@1,6:10='parrt',<2>,1:6]
[@2,12:11='<EOF>',<-1>,2:0]
含義:
"@0" : 表示第1個token(詞)
"0:4":表示[0,4]位置上內容
"<1>": 表示token類型——類型1
"1:0": 表示第1行,第0個位置開始
"@1" : 表示第2個token(詞)
"6:10": 表示[6,10]位置上的內容
"<2>": 表示token類型——類型2 : ID
"1:6": 表示第1行,第6個位置開始
3、文法二
<b>ArrayInit.g4</b>
grammar ArrayInit;
init : '{' value (',' value)* '}' ; //{ + value + 后面跟著多個 ",value" + }
value : init | INT ;
INT :[0-9]+ ;
WS : [\t\r\n]+ -> skip ;
規則表達式:小寫的
標識符:大寫的
4、詞法解析二
<b>解析詞二: {99, 3, 451}</b>
[@0,0:0='{',<1>,1:0]
[@1,1:2='99',<4>,1:1]
[@2,3:3=',',<2>,1:3]
[@3,5:5='3',<4>,1:5]
[@4,6:6=',',<2>,1:6]
[@5,8:10='451',<4>,1:8]
[@6,11:11='}',<3>,1:11]
總共有7個詞,分別是:
"{" //第1個詞,[0,0]位置上內容,第1種類型,第1行:第index=0開始
"99" //第2個詞,[1,2]位置上內容,第4種類型,第1行:第index=1開始
","http://第3個詞,[3,3]位置上內容,第2種類型,第1行:第index=3開始
"3"
","
"451"
"}"
解析結果成語法樹:(init { (value 99) , (value 3) , (value 451) })
待思考:
問題:第X種類型是怎么出來的呢?