语法分析器c语言实验报告,词法分析实验报告(C++)..doc
詞法分析實(shí)驗(yàn)報(bào)告(C).
詞法分析實(shí)驗(yàn)報(bào)告
一、實(shí)驗(yàn)?zāi)康?/p>
1. 掌握詞法分析的原理。
2. 熟悉保留字表等相關(guān)的數(shù)據(jù)結(jié)構(gòu)與單詞的分類(lèi)方法。
3. 掌握詞法分析器的設(shè)計(jì)與調(diào)試。
二、實(shí)驗(yàn)內(nèi)容
根據(jù)編譯中的分詞原理,用C++語(yǔ)言編寫(xiě)一個(gè)C語(yǔ)言的詞法分析程序:.
三、實(shí)驗(yàn)要求
1. 輸入:任意一個(gè)C語(yǔ)言程序的源代碼。
2. 處理:對(duì)輸入進(jìn)行分析,分離出保留字、標(biāo)識(shí)符、常量、算符和界符。
3. 輸出:對(duì)應(yīng)的二元式
四、實(shí)驗(yàn)環(huán)境
Windows XP Professional SP3,Visual Studio 2010
五、關(guān)鍵代碼
// Scanner.cpp
#include "stdafx.h"
#include "CuteC.h"
#include "Scanner.h"
#include "CuteCView.h"
int CScanner::m_constListIndex=0;
int CScanner::g_place=0;
// CScanner
IMPLEMENT_DYNAMIC(CScanner, CWnd)
CScanner::CScanner()
{
}
CScanner::CScanner(CString str)
{
//初始化保留字
reservedWords[0].str=L"void";
reservedWords[0].tok=tokentype::_VOID;
reservedWords[1].str=L"char";
reservedWords[1].tok=tokentype::CHAR;
reservedWords[2].str=L"const";
reservedWords[2].tok=tokentype::_CONST;
reservedWords[3].str=L"double";
reservedWords[3].tok=tokentype::DOUBLE;
reservedWords[4].str=L"else";
reservedWords[4].tok=tokentype::ELSE;
reservedWords[5].str=L"float";
reservedWords[5].tok=tokentype::FLOAT;
reservedWords[6].str=L"for";
reservedWords[6].tok=tokentype::FOR;
reservedWords[7].str=L"if";
reservedWords[7].tok=tokentype::IF;
reservedWords[8].str=L"int";
reservedWords[8].tok=tokentype::INT;
reservedWords[9].str=L"main";
reservedWords[9].tok=tokentype::MAIN;
reservedWords[10].str=L"scanf";
reservedWords[10].tok=tokentype::SCANF;
reservedWords[11].str=L"printf";
reservedWords[11].tok=tokentype::PRINTF;
reservedWords[12].str=L"while";
reservedWords[12].tok=tokentype::WHILE;
m_error=FALSE;
m_strText=str;
m_nLength=m_strText.GetLength();
m_cChar=m_strText.GetBuffer(m_nLength);//數(shù)組化字符串
m_nCount=0;
m_row=1;
m_col=0;
}
CScanner::~CScanner()
{
}
BEGIN_MESSAGE_MAP(CScanner, CWnd)
END_MESSAGE_MAP()
// 檢查標(biāo)識(shí)符是不是保留字,是就返回保留字類(lèi)型
CScanner::tokentype CScanner::reservedlookup(CString str)
{
for(int i=0;i<13;i++)
{
if(str==reservedWords[i].str)
return reservedWords[i].tok;
}
return tokentype::ID;
}
// 取下一個(gè)字符
wchar_t CScanner::getnextchar(void)
{
if(m_nCount>=m_nLength)
{
m_nCount++;
return ' ';
}
總結(jié)
以上是生活随笔為你收集整理的语法分析器c语言实验报告,词法分析实验报告(C++)..doc的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: SQLite 3 一些基本的使用
- 下一篇: s3c2440移植MQTT