1 第二章 程式語言的語法 陳維魁 博士 [email protected] 儒林圖書公司

43
1 第第第 第第第第第第第 第第第 第第 [email protected] 第第第第第第

Post on 19-Dec-2015

245 views

Category:

Documents


2 download

TRANSCRIPT

Page 1: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

1

第二章 程式語言的語法

陳維魁 博士[email protected]

儒林圖書公司

Page 2: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

2

大綱 基本定義 文法四要素 文法的分類 正規文法分類 B.N.F. 文法 剖析樹

模擬兩可的文法 懸置 else 問題 描述程式語言語法的

方式 語意的描述 精選習題

Page 3: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

3

基本定義

字元集 一組有限符號的集合稱之為字元 集

字元集有二類 ASCII Code Set EBCDIC Code Set

Page 4: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

4

ascii table

Page 5: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

5

基本定義

ASCII Code Set American Standard Code for Information In

terchange 的縮寫 標準的 ASCII Code 有 7 個位元

可表示 27 = 128 種不同的字元 一般使用在 IBM PC 及 Apple II 上 現今使用的 ASCII Code 已經擴充為 8 個位 元,稱之為 ASCII-8

Page 6: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

6

基本定義

EBCDIC Code Set Extended Binary Code Decimal Interchange

Code 的縮寫 標準的 EBCDIC Code 有 8 個位元

可表示 28=256 種不同的字元 一般使用在 IBM 360 及 FACOM 機器上

Page 7: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

7

基本定義

字串 (String) 定義

S=t1t2...tn, ti T 其中 T 為字元集 S 是由 T 中的字元所組成的一串列

n=4 則 S 可能為 abcd , ABCD , AEFG 等等

字串的長度 設 S=t1t2...tn則 S 的長度可表為│ S│=n

S 的長度為 n

Page 8: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

8

基本定義

字串的連接 設 p 與 q 為二字串且 p=m1m2…mu , q

=n1n2…nv

p q=m‧ 1m2...mun1n2...nv

表示二字串的連接且│ p‧q│=u+v p‧q 字串的長度為 u+v

Page 9: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

9

基本定義

空字串 通常以 “ ε” 表示空字串,且│ ε│=0, 有時空字串也可以 “”表示

Page 10: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

10

基本定義

T *

由 T 中的字元所組成任意長度 的字串的集合

實例 假設 T={p , q} 則T* ={ε , p , q , pp , q

q , pq , qp , pppp...}

Page 11: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

11

基本定義

語言 (Language) 若 L 為一語言,則 L 是T* 的一組子集合

(subset) 實例

假設 T={p , q} 則 L 可為 {p , pq , qp , ...} 或 {ppp , qqq , pqp , qpq , ...} 等等

只要是T* 的子集合即可

Page 12: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

12

基本定義

語言的乘積 (product) L1 與 L2 的乘積

L1‧L2={a‧b│a L1 , b L2} 範例

L1={p , q}   L2={m , n , mn , nm} L1‧L2={pm , pn , pmn , pnm , qm , qn , qmn , qnm}

Page 13: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

13

基本定義

語言 L 的次方 (Power) 定義 Lo={ε}   Ln=L‧Ln-1

範例 假設 L={p , pq , q} L0={ε} , L1=L , L2=L‧L ,… .

Page 14: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

14

基本定義

L*的定義 L* 又稱“ Kleene Closure of L” L 做任意次乘積 (product) 的集合 L*=L0L1L2...Ln...

Page 15: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

15

基本定義

L+ 的定義 又稱為“ Transitive Closure of L” L+=L1L2L3...Ln...

Page 16: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

16

文法四要素

T 終端符號 表示不能再以其他符號來替代

N 非終端符號 表示可以再以其他符號來替代 而 N與 T須具以下的關係: N∩T=Ø

Page 17: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

17

文法四要素

S starting symbol 起始符號 從事文法推演之步驟由 S開始

P production rule 文法產生規則

Page 18: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

18

文法的分類

Type 0 無任何限制

Type 1 Context sensitive grammar

Type 2 Context free grammar

Type 3 正規文法 (regular grammar)

Page 19: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

19

正規文法分類

右線性正規文法 right linear regular grammar 文法產生規需滿足

AuB or A u ,其中 A,BN , u T 左線性正規文法

left linear regular grammar 文法產生規則需滿足

uAB or A u ,其中 A,BN , u T

Page 20: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

20

B.N.F. 文法

B.N.F. grammar Backus Naur Form grammar type 2 grammar context-free grammar

Page 21: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

21

B.N.F. 文法符號 “::=”

表示“定義為” “{}”

表示出現 0次 ,1 次 ,... “〔〕”

表示出現 0次或 1次 “∣”

表示“ OR” ”< >”

表示非終端符號

Page 22: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

22

範例

Using the following B.N.F. grammar to construct a parse tree for the statement below

A:=B DIV 10 + C×D <assign>::=id:=<exp> <exp>::=<term>∣<exp>+<term>∣<exp>-<term> <term>::=<factor>∣<term>×<factor>∣<te

rm> DIV <factor> <factor>::=id∣int∣(<exp>)

Page 23: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

23

推導過程 <assign> ::= id := <exp>

:= <exp> + <term>:= <term> + <term>:= <term> DIV <factor> + <term>:= <factor> DIV <factor> + <term>:= id DIV <factor> + <term>:= id DIV int + <term>:=id DIV int + <term> * <factor>:=id DIV int + <factor> * <factor>:= id DIV int + id * <factor>:= id DIV int + id * id

Page 24: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

24

剖析樹

<assign>

id <exp>:=(A)

<exp> <term>+

<term> <factor>*<term>

<term> <factor>DIV <factor> id(D)

id(C)

int(10)

<factor>

id(B)

Page 25: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

25

剖析樹 (parse tree)

定義 根據語言的 B.N.F. 描述 ,將運算式轉換成相對應的樹狀結構 ,則稱此樹狀結構為剖析樹

Page 26: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

26

模擬兩可的文法

ambiguous grammar 根據語言的 B.N.F. 描述 ,對同一句子

(sentence) 可繪出二個或二個以上不同的剖析樹 , 則稱此語言的文法是模擬兩可的

Page 27: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

27

模擬兩可的文法 Draw 2 different parse tree for id+id+id,

using the grammar E→E+E∣id

E

E + E

E + E id

id id

E

E + E

E + Eid

id id

對 id+id+id 可畫出二個不同的剖析樹如下

故此文法是模擬兩可的

Page 28: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

28

模擬兩可的文法

Is the following grammar ambiguous? Describe your response carefully? S→aSbS∣bSaS∣ε

如 abab 1. S 2. S a S b S a S b S b S a S ε a S b S

ε ε ε ε

Page 29: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

29

懸置 else 問題

dangling else 的意義 若有一敘述如下 : if 條件 A then if 條件 B then E1 else E2 則 else 將無法確定要與第一個或第二個 if 結合這種現象 , 就是所謂的 dangling else 問題

Page 30: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

30

懸置 else 問題

各種語言解決 dangling else 的方法 PASCAL

利用 begin-end 作為分界,來解決懸置 else 問題 ALGOL 60

利用 begin-end 作為分界,來解決懸置 else 問題 ALGOL 68

利用 if...fi 作為分界,來解決懸置 else 的問題 近代高階程式語言

多利用”最接近未結合原則”來解決此問題

Page 31: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

31

描述程式語言語法的方式

B.N.F. 法請參考 sec. 2-4 之敘述

語法圖 (Syntax Diagram) 推移圖 (Transition Diagram)

Page 32: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

32

語法圖

:表示非終端符號 : 表示終端符號 P::=Q1│Q2│‧‧‧│Qn

  Q 1

Q 2

Q n

.

.

.

Page 33: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

33

語法圖 P::=Q1 Q2‧‧‧Qn

P::={Q}

Q 1 Q 2 . . . Q n

Q

Page 34: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

34

推移圖

1+0+對應的推移圖

S 0 S 1 S 2

1 01 0

其中 S0 為起始狀態,而 S2 為終止狀態

Page 35: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

35

推移圖

10*1+ 對應的推移圖

S 0 S 1 S 2

1 10 1

其中 S0 為起始狀態,而 S2 為終止狀態

Page 36: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

36

推移圖

10*110*1 對應的推移圖

S 0 S 1 S 2

1 10

S 3 S 4

10

1

其中 S0 為起始狀態,而 S4 為終止狀態

Page 37: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

37

語意的描述

靜態語意 (static semantics)動態語意 (dynamic semantics)

解釋型語意 (interpretive semantics) 公理型語意 (axiomatic semantics) 符號型語意 (denotational semantics)

Page 38: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

38

靜態語意 意義

由於有許多語言規則沒有辦法單純的用 BNF 文法來做一個描述,因此必需要用其他的規則來加以處理

作法 在程式執行之前或語言處理器翻譯時處理

範例 變數必須先宣告再引用

屬性文法 (attribute grammar) 屬性文法是一種可以描述靜態語意之方法

Page 39: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

39

動態語意 解釋型語意 (interpretive semantics) 公理型語意 (axiomatic semantics) 符號型語意 (denotational semantics)

Page 40: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

40

解釋型語意 意義

又稱為操作型語意 (operational semantics) , 在本方法中定義抽象機器 (abstract machine) ,此抽象機器可支援一組簡單的操作並提供一些簡單的資料結構供使用。通常以暫存器或記憶體位置來表示計算機執行的狀態

作法 語言的語意在此類型中,被定義成為如何將程式轉換

成在抽象機器上執行的碼 範例

如 PL/1 語言的維也納定義語言 (Vienna Definition Language)

Page 41: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

41

公理型語意

意義 公理型語意提供數學規則來表示程式執行之結果。

作法 對於程式語言的每個語法單元均提供一個數學規則來定義。也就是利用數學推論來証明程式的正確性

Page 42: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

42

符號型語意

意義 符號型語意利用數學函數來定義程式。

作法 syntax entity object

Page 43: 1 第二章 程式語言的語法 陳維魁 博士 wkchen@pchome.com.tw 儒林圖書公司

43

精選習題

請解釋下列名詞: 關鍵字 (key word)保留字 (reserved word) 懸置指標 (dangling pointer) 懸置標記引用 (dangling label reference)

剖析樹 (parse tree) 的樹葉節點是否有特殊意義