在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Stanford編譯原理詳解

處理器與AI芯片 ? 來源:處理器與AI芯片 ? 2023-10-25 10:47 ? 次閱讀

第二部分的作業(yè)是語法分析,通過編寫cool.y(這個assignment的任務),利用bison將其自動生成語法分析LALR(1)的代碼。

語法分析,就是將詞法分析階段已經(jīng)識別好的token,按照語法的規(guī)則,構建抽象語法樹的過程。

比如以下的代碼:

x=(a+b)*(c-d);

可以構成下圖的抽象語法樹:

        =
       / 
      x   *
         / 
        +   -
       /  / 
abcd

具體在cool.y 中,

b1d10848-72dd-11ee-939d-92fbcf53809c.png

這部分定義了非終結符non-terminal對應的semanticvalue. Union中的每一個field都可以是parsing動作的結果。

在stanfordcompiler的教學語言cool中,這就對應了AST的一個node。每一個non-terminal,都有其對應的semanticvalue。

左側的各種類型在cool-tree.aps中都有對應定義,比如Features:

b1f78f4a-72dd-11ee-939d-92fbcf53809c.png

Feature即為class中的成員函數(shù)或者成員變量。因為可以有多個Feature,所以存在Features,即LIST[Feature].

下面則具體定義了所有的非終結符對應的AST節(jié)點類型。<>內部的,比如classes是在union中定義的value,而右側的,比如class_list,我們需要定義規(guī)約該非終結符時,需要進行的操作。

b219db4a-72dd-11ee-939d-92fbcf53809c.png

上圖中$$即為action的返回值,對應該抽象語法樹AST對應的node。

下面介紹如何聲明非終結符對應的規(guī)約操作。

b243dc06-72dd-11ee-939d-92fbcf53809c.png

具體如何對類的聲明構建抽象語法樹節(jié)點,即class的規(guī)則:

1)

CLASS TYPEID '{' feature_list '}' ';'
{
/*對應動作 action*/
  $$=class_($2,
  idtable.add_string("Object"),
  $4,
  stringtable.add_string(curr_filename));
}

其動作對應cool-tree.aps中生命的constructor,

b25be4e0-72dd-11ee-939d-92fbcf53809c.png

傳給class_的參數(shù)即為

1)類名稱 2)父類名稱 3)成員變量/成員函數(shù)

4)文件名

對應的位置如類名稱即為TYPEID,對應$2, feature_list對應$4,因此其動作action寫成了如上圖所示的樣子。

cool語法中,如果class類沒有繼承自其他類,那么默認繼承自Object類型,因此parent設置為Object。

2)

CLASS TYPEID INHERITS TYPEID '{' feature_list '}' ';'
{$$=class_($2,$4,$6,
stringtable.add_string(curr_filename));}

這里唯一不同的即為該類繼承自父類,因此其第2個參數(shù),父類名稱傳入了$4。具體的序號可以參考第205行的注釋。

審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 函數(shù)
    +關注

    關注

    3

    文章

    4374

    瀏覽量

    64395
  • 代碼
    +關注

    關注

    30

    文章

    4891

    瀏覽量

    70360
  • 編譯
    +關注

    關注

    0

    文章

    676

    瀏覽量

    33828

原文標題:Stanford 編譯原理 編程作業(yè)2

文章出處:【微信號:處理器與AI芯片,微信公眾號:處理器與AI芯片】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    一文詳解編譯系統(tǒng)

    什么是編譯器?為什么要有編譯器?編譯器的作用是什么?編譯系統(tǒng)的組成部分有哪些,它們之間的關系是什么?有一句名言說的非常好:了解一件事情最好從它的歷史開始。要想對整個
    發(fā)表于 09-20 09:09 ?1748次閱讀

    嵌入式開發(fā)中的交叉編譯詳解

    在嵌入式開發(fā)中,經(jīng)常會遇到目標平臺資源貧乏,無法運行需要的編譯器。亦或是目標平臺上不允許或不能夠安裝需要的編譯器。這時候就需要使用交叉編譯了。
    的頭像 發(fā)表于 12-01 13:24 ?1779次閱讀
    嵌入式開發(fā)中的交叉<b class='flag-5'>編譯</b><b class='flag-5'>詳解</b>

    gcc編譯出錯

    1、信息說明 硬件平臺:JZ24402、問題現(xiàn)象 1) 第005節(jié)_Makefile的引入及規(guī)則_P test無法編譯編譯如下 2) gcc編譯器1_gcc常用選項__gcc編譯過程
    發(fā)表于 04-01 07:45

    WinCE系統(tǒng)的編譯過程詳解

    在WinCE系統(tǒng)中,當我們完成了相關的開發(fā)和系統(tǒng)定制工作以后,會編譯WinCE系統(tǒng),最后生成NK.bin和NK.nb0。我現(xiàn)在用WinCE6.0在自己的PC上面編譯一次用時19分16秒(有一天無聊,就測了一下)
    發(fā)表于 07-20 11:52 ?2206次閱讀
    WinCE系統(tǒng)的<b class='flag-5'>編譯</b>過程<b class='flag-5'>詳解</b>

    QT/E和Qtopia的編譯詳解

    首先說說編譯PC上的QT/E,我起初的時候不知道編譯PC上的QT/E編譯qpe和交叉編譯后的qpe有什么不同,
    發(fā)表于 05-10 10:53 ?2968次閱讀

    PICC編譯器的庫函數(shù)詳解

    本章將詳細列出PICC編譯器的庫函數(shù)。每個函數(shù)均從函數(shù)名開始,然后按照以下幾個標題給出詳細解釋。
    發(fā)表于 10-14 14:17 ?0次下載

    Vivado中的Incremental Compile增量編譯技術詳解

    Incremental Compile增量編譯是Vivado提供的一項高階功能。目的旨在當設計微小的改變時,重用綜合和布局布線的結果,縮短編譯時間。
    的頭像 發(fā)表于 07-05 06:06 ?1.1w次閱讀

    Linux內核編譯過程詳解

    Linux內核編譯過程詳解(kernel2.6.7) 花了幾天才編譯成功kernel2.6.7,其過程真可謂艱辛。古語有云:苦盡甘來!現(xiàn)在終于可以樂上一陣了。由于許多朋友對操作的順序及某些重要的配置
    發(fā)表于 11-07 11:16 ?4次下載

    編譯器是如何工作的_編譯器的工作過程詳解

    隨著計算機的發(fā)展,編譯器已經(jīng)發(fā)揮著十分重要的作用。本文主要介紹了編譯器的種類、編譯器的工作原理以及編譯器工作的具體操作過程及步驟詳解
    發(fā)表于 12-19 12:54 ?1.7w次閱讀

    Prelink的交叉編譯和使用詳解

    Prelink的交叉編譯和使用詳解
    的頭像 發(fā)表于 06-20 12:03 ?3864次閱讀
    Prelink的交叉<b class='flag-5'>編譯</b>和使用<b class='flag-5'>詳解</b>

    Php+mysql+apache編譯安裝詳述

    Php+mysql+apache編譯安裝詳述(深圳市核達中遠通電源技術股份有限公司大嗎)-文檔為Php+mysql+apache編譯安裝詳述詳解文檔,是一份不錯的參考資料,感興趣的可以下載看看,,,,,,,,,,,,,,,
    發(fā)表于 09-18 14:42 ?2次下載
    Php+mysql+apache<b class='flag-5'>編譯</b>安裝詳述

    詳解OpenHarmony的編譯和燒錄

    在上一篇【博流 BL-HWC-G1 開發(fā)板試用】開箱及編譯燒錄官方程序(BL602 IoT SDK)中,我們講了這塊開發(fā)板使用官方SDK進行編譯燒錄,這一篇,我們來講OpenHarmony的編譯
    的頭像 發(fā)表于 11-08 09:58 ?6048次閱讀
    <b class='flag-5'>詳解</b>OpenHarmony的<b class='flag-5'>編譯</b>和燒錄

    C語言中條件編譯詳解

    —般情況下,C語言源程序中的每一行代碼.都要參加編譯。但有時候出于對程序代碼優(yōu)化的考慮,希望只對其中一部分內容進行編譯。此時就需要在程序中加上條件,讓編譯器只對滿足條件的代碼進行編譯
    的頭像 發(fā)表于 04-14 13:12 ?3386次閱讀

    Stanford編譯的原理是什么?

    第一個作業(yè)是根據(jù)這門課定義的cool語言,寫一個詞法分析的rule,詞法分析對我?guī)椭淮螅饕抢斫馐褂镁涂梢裕痛蟛糠謪⒄誫ithub上的實現(xiàn)了。
    的頭像 發(fā)表于 09-02 09:55 ?737次閱讀
    <b class='flag-5'>Stanford</b><b class='flag-5'>編譯</b>的原理是什么?

    Stanford DG645開機無反應維修:安泰維修過程分享

    近期北京某院校送修一臺Stanford斯坦福DG645數(shù)字延時脈沖發(fā)生器,報修故障為不能正常開機。對儀器進行初步檢測,儀器外觀正常,開機無反應,確定故障與客戶報修一致。
    的頭像 發(fā)表于 05-08 17:54 ?203次閱讀
    <b class='flag-5'>Stanford</b> DG645開機無反應維修:安泰維修過程分享
    主站蜘蛛池模板: 免费视频不卡一区二区三区 | 天堂网中文在线 | 夜夜操美女 | 依依成人精品无v国产 | 日韩三级 | 婷婷综合在线观看丁香 | 成人午夜大片免费视频77777 | 大尺度免费高清在线观看视频 | 伊人久久大香线蕉综合电影 | 禁h粗大太大好爽好涨受不了了 | 九九热精品在线 | h视频国产 | 日本黄页网址 | 性xxxfreexxxx性欧美 | 久久狠狠躁免费观看 | 在线播放网址 | 亚洲成av人片在线观看无码 | 久久综合九色综合98一99久久99久 | 激激婷婷综合五 | 国产91小视频在线观看 | 欧美猛交xxxx乱大交 | 亚洲a在线播放 | aika中文字幕永久在线 | 午夜视频免费在线播放 | 黄网站在线观看视频 | 亚洲 欧美 另类 综合 日韩 | 四虎永久在线精品视频免费观看 | 在线网站 看片 网站 | 天天想天天干 | 色偷偷成人 | h黄网站 | 天天在线影院 | 毛片一区 | 五月天婷婷综合 | 亚洲free | 免费观看黄a一级视频日本 免费观看黄色网页 | 噜色| 午夜操一操| 欧美一级二级三级视频 | 午夜国产在线观看 | 日本成片视频 |