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

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

3天內(nèi)不再提示

Stanford編譯的原理是什么?

處理器與AI芯片 ? 來源:處理器與AI芯片 ? 2023-09-02 09:55 ? 次閱讀

第一個作業(yè)是根據(jù)這門課定義的cool語言,寫一個詞法分析的rule,詞法分析對我?guī)椭淮?,主要是理解使用就可以,就大部分參照github上的實現(xiàn)了。

Workflow

1)cool/include/PA2/cool-parse.h 里面定義了需要處理的關(guān)鍵字

/* Tokens.  */
#define CLASS 258
#define ELSE 259
#define FI 260
#define IF 261
#define IN 262
#define INHERITS 263
....

2) 實驗的主要內(nèi)容是在cool.flex中增加對關(guān)鍵字,注釋,嵌入注釋,字符串的處理。在cool.flex內(nèi)部定義好規(guī)則時候,make flexer 時,會調(diào)用flex. flex 輸入cool.flex, 輸出cool-lex.cc,這個就是flex自動產(chǎn)生的處理詞法的代碼。

3)產(chǎn)生flex后,可以調(diào)用perl pa1-grading.pl,打分會報告哪些沒有處理好

4)沒有處理好的

c53e8d20-48b6-11ee-97a6-92fbcf53809c.png

對于這種,可以直接grep “l(fā)ine number test 2”,查看時那個文件沒有處理好。./grading 目錄下有一堆輸入文件

c558845a-48b6-11ee-97a6-92fbcf53809c.png

可以直接調(diào)用 ./lexer ./gool.cool 或者出錯的文件 ./lexer ./lineno2.cool

它會根據(jù)我們輸入的規(guī)則,print信息。

c57296f6-48b6-11ee-97a6-92fbcf53809c.png

我的問題是注釋里面遇到換行,沒有增加linenumber,在comment里面加上遇到換行符時,遞增linenumber就對了。

上面是環(huán)境的問題,下面是除了課程的資料以外需要了解的內(nèi)容。

背景知識

遇到的問題我就直接問chatgpt了。

1)Flex支持的函數(shù):

yymore(): As mentioned earlier, this function is used to accumulate text from multiple rule matches before taking action. It’s particularly useful when you want to combine consecutive matches into a single token.

yytext: As discussed before, this global variable holds the current matched text or lexeme. It’s automatically populated by Flex based on the pattern that matches.

yylineno: This global variable keeps track of the current line number being processed by the lexer. You can use it to maintain accurate line number information for error reporting or other purposes.

我列出了主要用的,主要用的還是yymore(),用來繼續(xù)處理token的內(nèi)容;另一個就是yytext 則是表示當(dāng)前匹配的內(nèi)容。這里主要是講數(shù)字,字符串以及自定義的object與符號表中的內(nèi)容連接起來。


c5ac864a-48b6-11ee-97a6-92fbcf53809c.png

2) 如何編寫cool.flex

對于關(guān)鍵字的支持比較簡單,主要還是支持字符串和注釋,以及嵌套注釋。

這里就是狀態(tài)機,初始時和正常狀態(tài)下都處于INITIAL狀態(tài),cool語言時的注釋以(*開頭,考慮到會存在嵌套注釋,因此在INITIAL,COMMENTS,INLINE_COMMENTS三種狀態(tài)下,都可能會遇到(*此時我們進入COMMENTS狀態(tài),因此BEGIN COMMENTS。

"(*" {
    comment_layer++;
    BEGIN COMMENTS;
}

在注釋中,遇到非特殊字符,不需要特殊處理,可以直接忽視,因此{}內(nèi)部都為空。

[^n(*]* { }

[()*] { }

在遇到換行符時,增加行數(shù)計數(shù)。


 {
    curr_lineno++;
}

這里的comment_layer–與上面的comment_layer++對應(yīng),進入comment時遞增,出comment遞減,主要是為了應(yīng)對嵌套注釋。在走到最外層時,回到INITIAL狀態(tài)。

"*)" {
    comment_layer--;
    if (comment_layer == 0) {
        BEGIN INITIAL;
    }
}

總結(jié)來說, 就是下面的這個規(guī)則

DEFINED STATE {
Action
}





審核編輯:劉清

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

    關(guān)注

    68

    文章

    19103

    瀏覽量

    228826
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    575

    瀏覽量

    20470
  • 狀態(tài)機
    +關(guān)注

    關(guān)注

    2

    文章

    491

    瀏覽量

    27458

原文標(biāo)題:Stanford 編譯原理 編程作業(yè)1

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

收藏 人收藏

    評論

    相關(guān)推薦

    淺析可提升Vivado編譯效率的增量編譯方法

    增量編譯:使用增量編譯滿足最后時刻 HDL 變動需求,僅針對已變動邏輯進行布局布線,從而可節(jié)省時間。
    的頭像 發(fā)表于 12-13 10:14 ?5306次閱讀

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

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

    如何讓OpenHarmony編譯速度“狂飆”

    OpenHarmony 有兩種編譯方式,一種是通過 hb 工具編譯,一種是通過 build.sh 腳本編譯。本文筆者將提升 build.sh 方式編譯速度的方法整理分享給大家。
    的頭像 發(fā)表于 02-14 09:31 ?1857次閱讀

    Stanford編譯原理詳解

    第二部分的作業(yè)是語法分析,通過編寫cool.y(這個assignment的任務(wù)),利用bison將其自動生成語法分析LALR(1)的代碼。
    的頭像 發(fā)表于 10-25 10:47 ?642次閱讀
    <b class='flag-5'>Stanford</b><b class='flag-5'>編譯</b>原理詳解

    [1.1.1]--什么是編譯原理

    編譯原理
    jf_60701476
    發(fā)布于 :2022年12月27日 10:57:13

    GAL編譯工具

    GAL編譯工具 Atmel提供的GAL編譯工具 4.8a版本
    發(fā)表于 04-14 15:42 ?83次下載

    PCM編譯碼實驗

    PCM編譯碼實驗 一、實驗?zāi)康?. 掌握PCM編譯
    發(fā)表于 10-21 13:35 ?9010次閱讀
    PCM<b class='flag-5'>編譯</b>碼實驗

    QT/E和Qtopia的編譯詳解

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

    誰能縮短大容量FPGA的編譯時間?增量式編譯QIC!

    增量式編譯(Incremental Compilation)是ALTERA為解決大容量FPGA設(shè)計編譯時間太長的問題給出的一個新式工具!在本文中我們將闡述QIC在縮短編譯時間方面的作用。
    發(fā)表于 12-25 11:26 ?4906次閱讀

    Keil編譯常見問題

    吳鑒鷹總結(jié)的Keil 編譯常見問題,吳鑒鷹總結(jié)的Keil 編譯常見問題。
    發(fā)表于 07-22 15:31 ?10次下載

    講述增量編譯方法,提高Vivado編譯效率

    當(dāng)RTL代碼修改較少時,使用增量編譯功能可以提高工程的編譯速度,Incremental Compile增量編譯是Vivado提供的一項高階功能。目的旨在當(dāng)設(shè)計微小的改變時,重用綜合和布局布線的結(jié)果,縮短
    的頭像 發(fā)表于 01-22 17:27 ?9972次閱讀
    講述增量<b class='flag-5'>編譯</b>方法,提高Vivado<b class='flag-5'>編譯</b>效率

    什么是預(yù)編譯

    預(yù)編譯就是處理以#開頭的指令,比如賦值#include包含的文件、#define宏定義的替換、條件編譯等。預(yù)編譯就是為編譯前做準(zhǔn)備工作的階段,主要處理以#開頭的預(yù)
    發(fā)表于 01-13 13:52 ?0次下載
    什么是預(yù)<b class='flag-5'>編譯</b>

    交叉編譯器安裝教程

    交叉編譯器中“交叉”的意思就是在一個架構(gòu)上編譯另外一個架構(gòu)的代碼,相當(dāng)于兩種架構(gòu)“交叉”起來了。Ubuntu 自帶的 gcc 編譯器是針對 X86 架構(gòu)的,而我們現(xiàn)在要編譯的是 ARM
    的頭像 發(fā)表于 09-29 09:12 ?3420次閱讀

    Linux內(nèi)核編譯腳本

    獲得編譯命令及選項 編譯linux時,默認不會顯示編譯的命令,如果你要獲得編譯命令及其選項,可以在make命令后面加上宏定義: make V= 1 如果希望
    的頭像 發(fā)表于 09-27 11:52 ?599次閱讀

    3568編譯環(huán)境搭建

    主要介紹如何在本地搭建編譯環(huán)境來編譯rockchipBBuildrootllinuxSDK的源代碼。d當(dāng)前sdk只支持在linux環(huán)境下編譯,并提供linux的交叉編譯工具。
    發(fā)表于 12-13 11:23 ?18次下載