編譯原理清華大學(xué)第9章符號(hào)表_第1頁(yè)
編譯原理清華大學(xué)第9章符號(hào)表_第2頁(yè)
編譯原理清華大學(xué)第9章符號(hào)表_第3頁(yè)
編譯原理清華大學(xué)第9章符號(hào)表_第4頁(yè)
編譯原理清華大學(xué)第9章符號(hào)表_第5頁(yè)
已閱讀5頁(yè),還剩8頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

第9章符號(hào)表在編譯程序中符號(hào)表用來(lái)存放語(yǔ)言程序中出現(xiàn)的有關(guān)標(biāo)識(shí)符的屬性信息,屬性信息集中反映了標(biāo)識(shí)符的語(yǔ)義特征屬性。9.1符號(hào)表的作用和地位9.2符號(hào)的主要屬性及作用9.3符號(hào)表的組織9.3符號(hào)表的管理9.1符號(hào)表的作用和地位(1)收集符號(hào)屬性。在編譯程序中符號(hào)表用來(lái)存放語(yǔ)言程序中出現(xiàn)的有關(guān)標(biāo)識(shí)符的屬性信息,符號(hào)表中所登記的信息在編譯的不同階段都要用到。(2)語(yǔ)義檢查的依據(jù)。在語(yǔ)義分析中,符號(hào)表所登記的內(nèi)容將用于語(yǔ)義檢查(如檢查一個(gè)名字的使用和原先的說(shuō)明是否一致)和產(chǎn)生中間代碼。(3)目標(biāo)代碼生成階段地址分配的依據(jù)。在目標(biāo)代碼生成階段,當(dāng)對(duì)符號(hào)名進(jìn)行地址分配時(shí),符號(hào)表是地址分配的依據(jù)。對(duì)一個(gè)多遍掃描的編譯程序,不同遍所用的符號(hào)表也往往各有不同。因?yàn)槊勘樗P(guān)心的信息各有差異。9.2符號(hào)的主要屬性及作用在整個(gè)編譯期間,對(duì)于符號(hào)表的操作大致可歸納為五類:?對(duì)給定名字,查詢名字是否已在表中;?往表中填入一個(gè)新的名字;?對(duì)給定名字,訪問它的某些信息;?對(duì)給定名字,填寫或更新它的某些信息;?刪除一個(gè)或一組無(wú)用的項(xiàng)。不同種類的表格所涉及的操作往往也是不同的。上述五個(gè)方面只是一些基本的共同操作。符號(hào)的主要符號(hào)屬性(信息)下述幾項(xiàng)通常都是需要的:1符號(hào)名

2符號(hào)的數(shù)據(jù)類型

3符號(hào)的存儲(chǔ)類別

4符號(hào)的作用域及可視性

5符號(hào)變量的存儲(chǔ)分配信息6符號(hào)的其它屬性(1)數(shù)組內(nèi)情向量(2)記錄結(jié)構(gòu)型的成員信息(3)函數(shù)及過程的形參9.3符號(hào)表的組織9.3.1符號(hào)表的總體組織第1種:把屬性種類完全相同的那些符號(hào)組織在一起,構(gòu)造出表項(xiàng)是分別為等長(zhǎng)的多個(gè)符號(hào)表。第2種:把所有語(yǔ)言中的符號(hào)都組織在一張符號(hào)表中。組成一張包括了所有屬性的龐大的符號(hào)表。

第3種:折衷方式是根據(jù)符號(hào)屬性相似程度分類組織成若干張表,每張表中記錄的符號(hào)都有比較多的相同屬性。

編譯程序按名字的不同種屬分別使用許多符號(hào)表,如常數(shù)表、變量名表、過程名表等等。SUBROUTINEINCWAP(M,N)10K=M+1M=M+4N=KRETURNEND經(jīng)編譯頭三階段后所產(chǎn)生的主要表格有:符號(hào)名表SNT;常數(shù)表CT;入口名表ENT;標(biāo)號(hào)表LT;四元式表QT

符號(hào)名表SNTNAMEINFORMATION(1)M啞元,整數(shù),變量(2)N啞元,整數(shù),變量(3)K整數(shù),變量

常數(shù)表CT

值(VALUE)

(1)1

(2)4

入口名表ENT

NAMEINFORMATION

(1)INCWAP二目子程序,入口QT(1)/*記錄入口名INCWAP的入口地址*/標(biāo)號(hào)表LT

LABLEINFORMATION

(1)10QT(4)/*記錄了標(biāo)號(hào)10對(duì)應(yīng)的四元式序列號(hào)*/9.3.2符號(hào)表項(xiàng)的排列符號(hào)表作為一個(gè)多元組,表中元組的排列組織是構(gòu)造符號(hào)表的重要成分。在編譯程序的整個(gè)工作過程中,符號(hào)表被頻繁地用來(lái)建立表項(xiàng),找查表項(xiàng),填充和引用表項(xiàng)的屬性。因此表項(xiàng)的排列組織對(duì)該系統(tǒng)運(yùn)行的效率起著十分重要的作用。在編譯程序中,符號(hào)表項(xiàng)的組織傳統(tǒng)上采用三種構(gòu)造方法。(1)線性組織(2)排序組織及二分法(3)散列法。9.3.3關(guān)鍵字域的組織

符號(hào)表的關(guān)鍵字域(段)就是符號(hào)名稱(1)等長(zhǎng)關(guān)鍵字域(段)符號(hào)表(2)不等長(zhǎng)關(guān)鍵字段符號(hào)表---采用關(guān)鍵字池的索引結(jié)構(gòu)。9.3.4其他域的組織(1)等長(zhǎng)屬性值域組織(2)不等長(zhǎng)屬性值域組織9.3.5下推鏈域的組織9.4符號(hào)表的管理

9.4.1符號(hào)表的初始化

9.4.2符號(hào)的登錄

9.4.3符號(hào)的查找

9.4.4符號(hào)表中分程序結(jié)構(gòu)層次的管理對(duì)于具有分程序型結(jié)構(gòu)的語(yǔ)言程序,不同層次分程序中定義的標(biāo)識(shí)符號(hào)具有不同的作用域和不同的可視性規(guī)則。通常對(duì)于具有分程序結(jié)構(gòu)的語(yǔ)言可用兩種方式組織它們的符號(hào)表:一是對(duì)每個(gè)分程序建立一個(gè)獨(dú)立的分表結(jié)構(gòu)的符號(hào)表;一是把各分程序符號(hào)組織在一張單表結(jié)構(gòu)的符號(hào)表中

分表結(jié)構(gòu)的組織管理其基本思想是,每當(dāng)編譯程序掃描到一個(gè)分程序結(jié)構(gòu)開始時(shí),為該分程序建立一張符號(hào)表,在該分程序中定義的標(biāo)識(shí)符,都被登錄在該符號(hào)表中。而當(dāng)編譯程序掃描到一個(gè)分程序的結(jié)束時(shí),編譯程序釋放為該分程序所建立的符號(hào)表。這種符號(hào)表的分表結(jié)構(gòu)與源程序的分程序?qū)哟谓Y(jié)構(gòu)一一對(duì)應(yīng)。單表結(jié)構(gòu)的組織管理:其基本思想是,所有分程序中定義的標(biāo)

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論