日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
總結C++詞法分析設計方法

下面文章從C++詞法分析的角度出發(fā),其實語言是一個句子的集合,而句子是由詞法分析器返回的記號組成的非線性結構,C++語法分析的任務是在詞法分析基礎上,根據(jù)語言的語法規(guī)則,把詞法符號分解成各類語法單位。

反映句子結構的***方法是樹,常用的有分析樹和語法樹。分析語法結構的基本方法有兩種:自上而下分析方法和自下而上分析方法。自上而下分析從根到葉子建立分析樹,而自下而上分析恰好相反。在這兩種情況下,分析器都是從左到右地掃描輸入,每次讀進一個記號。與C++詞法分析類似,語法分析也具有雙重含義:

①規(guī)定句子形成的規(guī)則,也被稱為語法規(guī)則。程序設計語言的大部分語法規(guī)則可以用上下文無關文法(ContextFreeGrammar,簡稱CFG)來描述。

②根據(jù)語法規(guī)則識別記號流中的評議結構,也被稱為語法分析。最有效的自上而下和自下而上的分析方法都只能處理上下文無關文法的子類,如LL文法和LR方法,但是它們已足以應付程序設計評議的絕大多數(shù)語法現(xiàn)象。

一、任務與目的

1、使用C/C++程序設計語言和遞歸下降子程序的方法編寫該函數(shù)繪圖語言的C++詞法分析器。并要求設計一個語法分析器的測試小程序來調(diào)用自己編寫的語法分析器測試各種不同的輸入。

2、語法分析的任務是在C++詞法分析基礎上,根據(jù)語言的語法規(guī)則,把詞法符號分解成各類語法單位。語法分析所依據(jù)的是語言的語法規(guī)則,語法規(guī)則通常用上下文無關文法描述。#t#

通過自己動手編寫語法分析器,掌握正規(guī)式與正規(guī)文法、上下文無關文法(CFG)、有推導的基本概念(推導、分析樹與語法樹、二義性及二義性的消除)、自上而下分析(遞歸下降子程序方法、預測分析表方法、LL(1)文法)、自下而上分析。理解如何理論聯(lián)系實際以及明白理論與實際的差別。

二、分析與設計

語法分析程序一般具有如下功能:對單詞符號串進行語法分析(根據(jù)語義規(guī)則進行推導和規(guī)約),識別出程序中的各類語法單位,最終判斷輸入串是否構成語法上正確的“程序”。

這里我們采用遞歸下降分析方法:直接以程序的方式模擬產(chǎn)生式產(chǎn)生語言的過程。它的基本設計思想是:為每一個非終結符構造一個子程序,每一個子程序的過程體中按該產(chǎn)生式的候選項分情況展開,遇到終結符直接匹配,而遇到非終結符就調(diào)用相應非終結符的子程序。

該分析從調(diào)用文法開始符號的子程序開始,直到所有非終結符都展開為終結符并得到匹配為止。若分析過程中達到這一步則表明分析成功,否則表明輸入中有語法錯誤。遞歸下降分析對文法的限制是不能有公共左因子和左遞歸。由于文法是遞歸定義的,因此子程序也是遞歸的。

對于規(guī)模比較小的語言,遞歸下降子程序方法是很有效的方法,它簡單靈活,容易構造,其缺點是程序與文法直接相關,對文法的任何改變均需對程序進行相應的修改。

這里給出C++詞法分析程序大概的設計方法:

1、根據(jù)要求寫出語法分析的上下文無關文法G;

2、消除上下文無關文法G的二義性;

3、消除上下文無關文法G的(直接)左遞歸,并提取左因子;

4、構造文法的狀態(tài)轉換圖并且簡化;

5、將轉換圖轉化為EBNF表示;

6、從EBNF構造遞歸下降子程序;

以下是較為詳細的設計:

總體結構與模塊劃分

語法測試模塊(parsermain.cpp)

語法分析器模塊(parser.h & parser.cpp)

繪圖語言解釋器入口

遞歸子程序集

先序遍歷并打印表達式的語法樹

出錯處理模塊

詞法分析器模塊(scanner.h & scanner.cpp)

初使化詞法分析器

識別出具有獨立意義的最小語法單位

輔助性模塊


本文題目:總結C++詞法分析設計方法
URL分享:http://www.5511xx.com/article/dpcoohg.html