日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

Stanford編譯的原理是什么?

處理器與AI芯片 ? 來源:處理器與AI芯片 ? 2023-09-02 09:55 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

第一個作業(yè)是根據(jù)這門課定義的cool語言,寫一個詞法分析的rule,詞法分析對我?guī)椭淮螅饕抢斫馐褂镁涂梢裕痛蟛糠謪⒄誫ithub上的實現(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 則是表示當前匹配的內(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++對應,進入comment時遞增,出comment遞減,主要是為了應對嵌套注釋。在走到最外層時,回到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)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 處理器
    +關(guān)注

    關(guān)注

    68

    文章

    20339

    瀏覽量

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

    關(guān)注

    1

    文章

    596

    瀏覽量

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

    關(guān)注

    2

    文章

    501

    瀏覽量

    29353

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    Stanford編譯原理詳解

    第二部分的作業(yè)是語法分析,通過編寫cool.y(這個assignment的任務(wù)),利用bison將其自動生成語法分析LALR(1)的代碼。
    的頭像 發(fā)表于 10-25 10:47 ?1224次閱讀
    <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編譯碼實驗 一、實驗目的1. 掌握PCM編譯
    發(fā)表于 10-21 13:35 ?9699次閱讀
    PCM<b class='flag-5'>編譯</b>碼實驗

    QT/E和Qtopia的編譯詳解

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

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

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

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

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

    什么是預編譯

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

    交叉編譯器安裝教程

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

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

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

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

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

    Triton編譯器與其他編譯器的比較

    Triton編譯器與其他編譯器的比較主要體現(xiàn)在以下幾個方面: 一、定位與目標 Triton編譯器 : 定位:專注于深度學習中最核心、最耗時的張量運算的優(yōu)化。 目標:提供一個高度抽象、靈活、高效
    的頭像 發(fā)表于 12-24 17:25 ?2058次閱讀

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

    近期北京某院校送修一臺Stanford斯坦福DG645數(shù)字延時脈沖發(fā)生器,報修故障為不能正常開機。對儀器進行初步檢測,儀器外觀正常,開機無反應,確定故障與客戶報修一致。
    的頭像 發(fā)表于 05-08 17:54 ?754次閱讀
    <b class='flag-5'>Stanford</b> DG645開機無反應維修:安泰維修過程分享

    斯坦福(Stanford)鎖相放大器故障修復

    斯坦福鎖相放大器是由斯坦福研究系統(tǒng)公司(Stanford Research Systems, SRS)研發(fā)的一款測量工具,主要用于微弱信號的測量和提取。它結(jié)合了高靈敏度、高精度、高穩(wěn)定性和多功能性于一體,是科研和工業(yè)領(lǐng)域的重要設(shè)備。
    的頭像 發(fā)表于 07-30 10:58 ?1063次閱讀
    斯坦福(<b class='flag-5'>Stanford</b>)鎖相放大器故障修復

    高精度信號源維修專家:Stanford DS360全流程修復

    高精度信號源維修專家:Stanford DS360全流程修復
    的頭像 發(fā)表于 12-19 15:49 ?636次閱讀
    高精度信號源維修專家:<b class='flag-5'>Stanford</b> DS360全流程修復
    尼勒克县| 双柏县| 筠连县| 陕西省| 安义县| 师宗县| 江陵县| 合作市| 柳河县| 巩留县| 克什克腾旗| 南皮县| 子长县| 康马县| 黔江区| 东海县| 岳普湖县| 清新县| 包头市| 尼木县| 濮阳市| 朔州市| 汤阴县| 石门县| 嘉义县| 丰镇市| 丁青县| 织金县| 武城县| 新津县| 广德县| 睢宁县| 博白县| 法库县| 石楼县| 云安县| 甘孜| 贵州省| 大英县| 肇庆市| 金昌市|