版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 編譯技術(shù)課程設(shè)計(jì)</b></p><p><b> 一、目的</b></p><p> <<編譯技術(shù)>>是理論與實(shí)踐并重的課程,而其實(shí)驗(yàn)課要綜合運(yùn)用一、二年級(jí)所學(xué)的多門(mén)課程的內(nèi)容,用來(lái)完成一個(gè)小型編譯程序。從而鞏固和加強(qiáng)對(duì)詞法分析、語(yǔ)法分析、語(yǔ)義分析、代碼生成和報(bào)錯(cuò)處理等理論的認(rèn)識(shí)和理解;
2、培養(yǎng)學(xué)生對(duì)完整系統(tǒng)的獨(dú)立分析和設(shè)計(jì)的能力,進(jìn)一步培養(yǎng)學(xué)生的獨(dú)立編程能力。</p><p><b> 二、任務(wù)及要求</b></p><p><b> 基本要求:</b></p><p> 詞法分析器 產(chǎn)生下述小語(yǔ)言的單詞序列</p><p> 這個(gè)小語(yǔ)言的所有的單詞符號(hào),以及它們的種別編碼
3、和內(nèi)部值如下表:</p><p> 對(duì)于這個(gè)小語(yǔ)言,有幾點(diǎn)重要的限制:</p><p> 首先,所有的關(guān)鍵字(如IF﹑WHILE等)都是“保留字”。所謂的保留字的意思是,用戶(hù)不得使用它們作為自己定義的標(biāo)示符。例如,下面的寫(xiě)法是絕對(duì)禁止的:</p><p> IF(5)=x </p><p>
4、其次,由于把關(guān)鍵字作為保留字,故可以把關(guān)鍵字作為一類(lèi)特殊標(biāo)示符來(lái)處理。也就是說(shuō),對(duì)于關(guān)鍵字不專(zhuān)設(shè)對(duì)應(yīng)的轉(zhuǎn)換圖。但把它們(及其種別編碼)預(yù)先安排在一張表格中(此表叫作保留字表)。當(dāng)轉(zhuǎn)換圖識(shí)別出一個(gè)標(biāo)識(shí)符時(shí),就去查對(duì)這張表,確定它是否為一個(gè)關(guān)鍵字。</p><p> 再次,如果關(guān)鍵字、標(biāo)識(shí)符和常數(shù)之間沒(méi)有確定的運(yùn)算符或界符作間隔,則必須至少用一個(gè)空白符作間隔(此時(shí),空白符不再是完全沒(méi)有意義的了)。例如,一個(gè)條件語(yǔ)句
5、應(yīng)寫(xiě)為</p><p> IF i>0 i= 1;</p><p><b> 而絕對(duì)不要寫(xiě)成</b></p><p> IFi>0 i=1;</p><p> 因?yàn)閷?duì)于后者,我們的分析器將無(wú)條件地將IFI看成一個(gè)標(biāo)識(shí)符。</p><p> 這個(gè)小語(yǔ)言的單詞符號(hào)的狀態(tài)轉(zhuǎn)換
6、圖,如下圖:</p><p> 語(yǔ)法分析器 能識(shí)別由加+ 減- 乘* 除/ 乘方^ 括號(hào)()操作數(shù)所組成的算術(shù)表達(dá)式,其文法如下:</p><p> E→E+T|E-T|T</p><p> T→T*F|T/F|F</p><p><b> F→P^F|P</b></p><p><
7、b> p→(E)|i</b></p><p> 使用的算法可以是:預(yù)測(cè)分析法;遞歸下降分析法;算符優(yōu)先分析法;LR分析法等。</p><p> 中間代碼生成器 產(chǎn)生上述算術(shù)表達(dá)式的中間代碼(四元式序列)</p><p><b> 三、實(shí)現(xiàn)過(guò)程說(shuō)明</b></p><p> 1、詞法分析器的流
8、程圖</p><p> 2、語(yǔ)法分析器流程圖</p><p> 3、中間代碼生成器流程圖</p><p><b> 四、源程序清單</b></p><p><b> 詞法分析器:</b></p><p> #include "stdafx.h"&
9、lt;/p><p> #include "iostream"</p><p> #include "string"</p><p> using namespace std;</p><p> //reserve保留字</p><p> string reserve[5]
10、= {"DIM","IF","DO","STOP","END"};</p><p> //結(jié)構(gòu)體數(shù)組,保存已識(shí)別的單詞</p><p> struct table</p><p><b> {</b></p><p>
11、; string str;</p><p> string name;</p><p> }table[400];</p><p> int count = 0;</p><p> //判斷是否為保留字</p><p> bool Reserve(string str)</p><p&g
12、t;<b> {</b></p><p> bool flag = false;</p><p> for(int i=0; i<sizeof(reserve); i++)</p><p><b> {</b></p><p> if(str == reserve[i])</p
13、><p><b> { </b></p><p> flag = true;</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p>&
14、lt;p> return flag;</p><p><b> }</b></p><p><b> //讀入源程序</b></p><p> string readStr() {</p><p><b> FILE *fp;</b></p>&l
15、t;p> string str = "";</p><p> char c, filename[20];</p><p> cout<<"輸入源文件名:";</p><p> cin>>filename;</p><p> if((fp = fopen(filen
16、ame,"r")) == NULL)</p><p><b> {</b></p><p> cout<<"file not found"<<endl;</p><p><b> } else {</b></p><p> wh
17、ile((c = fgetc(fp)) != EOF)</p><p><b> { </b></p><p><b> str += c;</b></p><p><b> }</b></p><p><b> }</b></p>
18、<p> return str;</p><p><b> }</b></p><p><b> //將結(jié)果顯示</b></p><p> void putToFile(struct table tablep[])</p><p><b> {</b><
19、;/p><p><b> char ch;</b></p><p> int i, j, k;</p><p> for(i=0; i<count; i++)</p><p><b> {</b></p><p> for(j=0; j<table[i].s
20、tr.size(); j++)</p><p><b> {</b></p><p> ch = table[i].str[j];</p><p><b> cout<<ch;</b></p><p><b> }</b></p><p&
21、gt; cout<<" ";</p><p> for(k=0; k<table[i].name.size(); k++)</p><p><b> {</b></p><p> ch = table[i].name[k];</p><p><b>
22、 cout<<ch;</b></p><p><b> }</b></p><p> cout<<endl;</p><p><b> }</b></p><p> cout<<"分析完畢!"<<endl;&l
23、t;/p><p><b> }</b></p><p><b> //詞法分析</b></p><p> void lex(string input)</p><p><b> {</b></p><p><b> char c;<
24、/b></p><p> string strToken;</p><p> int i = 0, n;</p><p> //i數(shù)組input游標(biāo);n數(shù)組input剩余長(zhǎng)度</p><p> n = input.size();</p><p> while(n > 0) </p>
25、<p><b> {</b></p><p> c = input[i++];</p><p><b> n --;</b></p><p> //找到第一個(gè)不為空的字符</p><p> while(c == ' ' || c == '\n' |
26、| c == '\t')</p><p><b> {</b></p><p> c = input[i++];</p><p><b> n --;</b></p><p><b> }</b></p><p> if(isa
27、lpha(c)) {</p><p> while(isalpha(c) || isdigit(c))</p><p><b> {</b></p><p> strToken += c;</p><p> c = input[i++];</p><p><b> n --;&
28、lt;/b></p><p><b> }</b></p><p> i--; //將游標(biāo)回退一位</p><p><b> n++; </b></p><p> table[count].str = strToken;</p><p> if(!Reserv
29、e(strToken))</p><p><b> {</b></p><p><b> //不是保留字</b></p><p> table[count++].name = "$ID";</p><p><b> } else {</b></
30、p><p> for(int k=0; k<sizeof(reserve); k++)</p><p><b> {</b></p><p> if(strToken == reserve[k])</p><p><b> {</b></p><p> table
31、[count++].name = "$"+reserve[k];</p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b>&
32、lt;/p><p> strToken = ""; //清空,以備下次使用</p><p> } else if(isdigit(c)) {</p><p> while(isdigit(c))</p><p><b> {</b></p><p> strToken
33、 += c;</p><p> c = input[i++];</p><p><b> n --;</b></p><p><b> }</b></p><p><b> i--;</b></p><p><b> n++;<
34、/b></p><p> table[count].str = strToken;</p><p> table[count++].name = "$INT";</p><p> strToken = "";</p><p> } else if(c == '*') {&l
35、t;/p><p> c = input[i++];</p><p><b> n--;</b></p><p> if(c == '*') { </p><p> table[count].str = "**";</p><p> table[count+
36、+].name = "$POWER";</p><p><b> } else {</b></p><p><b> i--;</b></p><p><b> n++;</b></p><p> table[count].str = "*
37、";</p><p> table[count++].name = "$STAR";</p><p><b> }</b></p><p><b> } else {</b></p><p> strToken += c;</p><p>
38、; table[count].str = strToken;</p><p> switch(c) {</p><p> //暫時(shí)識(shí)別以下符號(hào)</p><p> case '#' : </p><p> table[count++].name = "$POUND";</p><
39、p><b> break;</b></p><p> case '"' : </p><p> table[count++].name = "$QUOTE";</p><p><b> break;</b></p><p> case &
40、#39;=' : </p><p> table[count++].name = "$ASSIG";</p><p><b> break;</b></p><p> case '+' : </p><p> table[count++].name = "$P
41、LUS";</p><p><b> break;</b></p><p> case ';' :</p><p> table[count++].name = "$SEMICOLON"; </p><p><b> break;</b>&
42、lt;/p><p> case '(' :</p><p> table[count++].name = "$LPAR";</p><p><b> break;</b></p><p> case ')' :</p><p> table
43、[count++].name = "$RPAR";</p><p><b> break;</b></p><p> case '{' : </p><p> table[count++].name = "$LBRACE";</p><p><b>
44、 break;</b></p><p> case ',' :</p><p> table[count++].name = "$COMMA"; </p><p><b> break;</b></p><p> case '}' :<
45、;/p><p> table[count++].name = "$RBRACE"; </p><p><b> break;</b></p><p> default : </p><p><b> count++;</b></p><p>&
46、lt;b> break;</b></p><p><b> }</b></p><p> strToken = "";</p><p><b> } </b></p><p><b> }</b></p><p
47、><b> }</b></p><p> void main()</p><p><b> {</b></p><p><b> while(1)</b></p><p><b> {</b></p><p> s
48、tring str;</p><p> str = readStr();</p><p><b> lex(str);</b></p><p> putToFile(table);</p><p><b> }</b></p><p><b> }<
49、/b></p><p><b> 語(yǔ)法分析器 :</b></p><p> #include "stdafx.h"</p><p> #include<iostream></p><p> #include<string></p><p>
50、 using namespace std;</p><p><b> void E();</b></p><p> void E1();</p><p><b> void T();</b></p><p> void T1();</p><p><b>
51、 void F();</b></p><p><b> string s;</b></p><p><b> int i;</b></p><p><b> int ERR;</b></p><p> int SwitchNum;</p>&
52、lt;p> int main()</p><p><b> {</b></p><p><b> do</b></p><p><b> {</b></p><p><b> s="";</b></p>&
53、lt;p><b> i=0;</b></p><p><b> ERR=0;</b></p><p> cout<<"請(qǐng)輸入你要分析的句子:"<<endl;</p><p><b> cin>>s;</b></p>&
54、lt;p> s.resize(s.size()+1);</p><p> s[s.size()-1]='#';</p><p><b> E();</b></p><p> if(s[i]=='#')</p><p> cout<<"是該文法產(chǎn)生的算術(shù)
55、表達(dá)式"<<endl;</p><p><b> else</b></p><p> cout<<endl;</p><p> cout<<"輸入繼續(xù),n退出:";</p><p> }while(cin>>SwitchNum);<
56、;/p><p><b> return 0;</b></p><p><b> }</b></p><p><b> void E()</b></p><p><b> { </b></p><p> if(ERR==0)&l
57、t;/p><p><b> {</b></p><p><b> T();</b></p><p><b> E1();</b></p><p><b> }</b></p><p><b> }</b>
58、</p><p><b> void E1()</b></p><p><b> {</b></p><p> if(ERR==0)</p><p><b> {</b></p><p> if(s[i]=='+')</p
59、><p><b> {</b></p><p><b> ++i;</b></p><p><b> T();</b></p><p><b> E1();</b></p><p><b> }</b>&
60、lt;/p><p> else if(s[i]!='#'&&s[i]!=')')</p><p><b> {</b></p><p> cout<<"不是該文法產(chǎn)生的算術(shù)表達(dá)式"<<endl;</p><p><b>
61、; ERR=1;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> void T()</b></p><p>&
62、lt;b> {</b></p><p> if(ERR==0)</p><p><b> {</b></p><p><b> F();</b></p><p><b> T1();</b></p><p><b>
63、 }</b></p><p><b> }</b></p><p><b> void T1()</b></p><p><b> {</b></p><p> if(ERR==0)</p><p><b> {<
64、/b></p><p> if(s[i]=='*')</p><p><b> {</b></p><p><b> ++i;</b></p><p><b> F();</b></p><p><b> T1(
65、);</b></p><p><b> }</b></p><p> else if(s[i]!='#'&&s[i]!=')'&&s[i]!='+')</p><p><b> {</b></p><p&g
66、t; cout<<"不是該文法產(chǎn)生的算術(shù)表達(dá)式"<<endl;</p><p><b> ERR=1;</b></p><p><b> }</b></p><p><b> }</b></p><p><b>
67、}</b></p><p><b> void F()</b></p><p><b> {</b></p><p> if(ERR==0)</p><p><b> {</b></p><p> if(s[i]=='(
68、39;)</p><p><b> {</b></p><p><b> ++i;</b></p><p><b> E();</b></p><p> if(s[i]==')')</p><p><b> ++i;&
69、lt;/b></p><p> else if(s[i]== '#')</p><p><b> {</b></p><p> cout<<"不是該文法產(chǎn)生的算術(shù)表達(dá)式"<<endl;</p><p><b> ERR=1;</b&
70、gt;</p><p><b> ++i;</b></p><p><b> }</b></p><p><b> }</b></p><p> else if(s[i]=='i')</p><p><b> ++i;
71、</b></p><p><b> else</b></p><p><b> {</b></p><p> cout<<"不是該文法產(chǎn)生的算術(shù)表達(dá)式"<<endl;</p><p><b> ERR=1;</b>
72、</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p><b> 中間代碼生成器:</b></p><p> #include "std
73、afx.h"</p><p> #include<stdlib.h></p><p> #include<fstream></p><p> #include<iostream></p><p> using namespace std;</p><p> #de
74、fine MAX 100</p><p> int m=0,sum=0;//sum用于計(jì)算運(yùn)算符的個(gè)數(shù)</p><p> //m用于標(biāo)記輸入表達(dá)式中字符的個(gè)數(shù)</p><p> char JG='A';</p><p> char str[MAX];//用于存輸入表達(dá)式</p><p> in
75、t token=0;//左括號(hào)的標(biāo)志</p><p> /***********用于更改計(jì)算后數(shù)組中的值**************/</p><p> void change(int e)</p><p><b> {</b></p><p> int f=e+2;</p><p>
76、 char ch=str[f];</p><p> if(ch>='A'&&ch<='Z')</p><p><b> {</b></p><p> for(int l=0;l<m+10;l++)</p><p><b> {</
77、b></p><p> if(str[l]==ch)</p><p> str[l]=JG;</p><p><b> }</b></p><p><b> }</b></p><p> if(str[e]>='A'&&s
78、tr[e]<='Z')</p><p><b> {</b></p><p> for(int i=0;i<m;i++)</p><p><b> {</b></p><p> if(str[i]==str[e])</p><p> st
79、r[i]=JG;</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> void chengchuchuli(int i,int m)</p><p><b&g
80、t; {</b></p><p><b> i++;</b></p><p> for( ;i<=m-1;i++)//處理乘除運(yùn)算</p><p><b> {</b></p><p> if(str[i]=='*'||str[i]=='/'
81、;) </p><p><b> {</b></p><p> cout<<"("<<str[i]<<" "<<str[i-1]<<" "<<str[i+1]<<" "<<JG<
82、<")"<<endl;</p><p> change(i-1);</p><p> str[i-1]=str[i]=str[i+1]=JG;</p><p><b> sum--;</b></p><p> JG=(char)(int)JG++;</p>&l
83、t;p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> void jiajianchuli(int j,int m)</p><p><b> {</b></p>
84、;<p><b> j++;</b></p><p> for( ;j<=m-1;j++)//處理加減運(yùn)算</p><p><b> {</b></p><p> if(str[j]=='+'||str[j]=='-') </p><p>
85、<b> {</b></p><p> cout<<"("<<str[j]<<" "<<str[j-1]<<" "<<str[j+1]<<" "<<JG<<")"<<
86、;endl;</p><p> change(j-1);</p><p> str[j-1]=str[j]=str[j+1]=JG;</p><p><b> sum--;</b></p><p> JG=(char)(int)JG++;</p><p><b> }</
87、b></p><p><b> }</b></p><p><b> }</b></p><p> /*掃描一遍從文件中讀入表達(dá)式*/</p><p> void scan(FILE *fin)</p><p><b> { </b>
88、</p><p> int p[MAX];</p><p> char ch='a';</p><p> int c=-1,q=0;</p><p> while(ch!=EOF)</p><p><b> {</b></p><p> ch=g
89、etc(fin);</p><p> while(ch==' '||ch=='\n'||ch=='\t') ch=getc(fin);//消除空格和換行符</p><p> str[m++]=ch;</p><p> if(ch=='='||ch=='+'||ch=='-&
90、#39;||ch=='*'||ch=='/') sum++;</p><p> else if(ch=='(') </p><p><b> {</b></p><p> p[++c]=m-1;</p><p><b> }</b></p
91、><p> else if(ch==')')</p><p><b> {</b></p><p><b> q=m-1;</b></p><p> chengchuchuli(p[c],q);//從左括號(hào)處理到又括號(hào)</p><p> jiajianc
92、huli(p[c],q); </p><p> JG=(char)(int)JG--;</p><p> str[p[c]]=str[m-1]=JG;</p><p><b> c--;</b></p><p> JG=(char)(int)JG++;</p><
93、;p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> /*對(duì)表達(dá)是進(jìn)行處理并輸出部分四元式*/</p><p> void siyuanshi()</p><p>&l
94、t;b> {</b></p><p> for(int i=0;i<=m-1;i++)//處理乘除運(yùn)算</p><p><b> {</b></p><p> if(str[i]=='*'||str[i]=='/') </p><p><b>
95、{</b></p><p> cout<<"("<<str[i]<<" "<<str[i-1]<<" "<<str[i+1]<<" "<<JG<<")"<<endl;</
96、p><p> change(i-1);</p><p> str[i-1]=str[i]=str[i+1]=JG;</p><p><b> sum--;</b></p><p> JG=(char)(int)JG++;</p><p><b> }</b></p
97、><p><b> }</b></p><p> for(int j=0;j<=m-1;j++)//處理加減運(yùn)算</p><p><b> {</b></p><p> if(str[j]=='+'||str[j]=='-') </p><
98、;p><b> {</b></p><p> cout<<"("<<str[j]<<" "<<str[j-1]<<" "<<str[j+1]<<" "<<JG<<")"&
99、lt;<endl;</p><p> change(j-1);</p><p> str[j-1]=str[j]=str[j+1]=JG;</p><p><b> sum--;</b></p><p> JG=(char)(int)JG++;</p><p><b>
100、}</b></p><p><b> } </b></p><p> for(int k=0;k<=m-1;k++)//處理賦值運(yùn)算</p><p><b> {</b></p><p> if(str[k]=='=') </p><p&
101、gt;<b> {</b></p><p> JG=(char)(int)--JG;</p><p> cout<<"("<<str[k]<<" "<<str[k+1]<<" "<<" "<<&
102、quot; "<<str[k-1]<<")"<<endl;</p><p><b> sum--;</b></p><p> change(k+1);</p><p> str[k-1]=JG;</p><p><b> }</b&
103、gt;</p><p><b> }</b></p><p><b> }</b></p><p> /***************主函數(shù)*******************/</p><p> void main(){</p><p> char in[MAX
104、]; //用于接收輸入輸出文件名</p><p> FILE *fin; //用于指向輸入輸出文件的指針</p><p><b> while(1)</b></p><p><b> {</b></p><p> cout<<"請(qǐng)輸入源程序文件名(例如ceshi.txt
105、):";</p><p><b> cin>>in;</b></p><p> cout<<endl;</p><p> if ((fin=fopen(in,"r"))==NULL) //判斷輸入文件名是否正確</p><p><b> {</
106、b></p><p> cout<<endl<<"打開(kāi)詞法分析輸入文件出錯(cuò)!"<<endl;</p><p><b> }</b></p><p> cout<<"四元式如下:"<<endl;</p><p>
107、 scan(fin);//調(diào)用函數(shù)從文件中讀入表達(dá)式 </p><p> /********調(diào)用生成四元式的函數(shù)********/</p><p> siyuanshi();</p><p> /*********判斷是否成功**********/</p><p> if(sum==0) cout<<"成功!
108、"<<endl;</p><p> else cout<<"有錯(cuò)誤!"<<endl;</p><p><b> //關(guān)閉文件</b></p><p> fclose(fin);</p><p><b> }</b></
109、p><p><b> }</b></p><p><b> 五、程序運(yùn)行結(jié)果</b></p><p><b> 詞法分析器</b></p><p><b> 測(cè)試用例:</b></p><p> DIM IF DO SDOP
110、END 76 = + * ** , ( )</p><p><b> 語(yǔ)法分析器</b></p><p><b> 測(cè)試用例:</b></p><p> ?。?)輸入i,預(yù)期顯示:是該文法產(chǎn)生的算術(shù)表達(dá)式</p><p> ?。?)輸入a,預(yù)期顯示:不是該文法產(chǎn)生的算術(shù)表達(dá)式&l
111、t;/p><p> (3)輸入((((i+i*i)))),預(yù)期顯示:是該文法產(chǎn)生的算術(shù)表達(dá)式</p><p> (4)輸入(i+i,預(yù)期顯示:不是該文法產(chǎn)生的算術(shù)表達(dá)式</p><p><b> 中間代碼生成器:</b></p><p><b> 測(cè)試用例</b></p><
112、p><b> x=i+i</b></p><p><b> y=i*i</b></p><p><b> z=i</b></p><p><b> a=(i+i)*i</b></p><p> b=(i+i)*i+i*i</p>
113、<p><b> 六、總結(jié)</b></p><p> 本課程設(shè)計(jì)程序是以C語(yǔ)言為基礎(chǔ),并整合了C、C++等一些編譯語(yǔ)言的思想,能夠?qū)崿F(xiàn)對(duì)整數(shù)的四則運(yùn)算以及相應(yīng)的賦值語(yǔ)句、條件語(yǔ)句和循環(huán)語(yǔ)句,其中以遞歸的思想實(shí)現(xiàn)了詞法分析、語(yǔ)法分析和語(yǔ)義分析,最終結(jié)果使用四元式輸出。增加了對(duì)注釋的分析,并能夠?qū)崿F(xiàn)文件的讀入,大大地增強(qiáng)了程序的可用性和效率。美中不足的是程序中沒(méi)有類(lèi)型檢查、沒(méi)
114、有布爾表達(dá)式的分析,結(jié)果只以中間代碼(四元式)表示,沒(méi)有生成目標(biāo)代碼,還有受文件操作的限制分析的程序不支持中文,這些也希望在以后的日子里繼續(xù)學(xué)習(xí)和完成。</p><p> 做這份課程設(shè)計(jì)也用了近一周的時(shí)間,整體來(lái)說(shuō)對(duì)課本的知識(shí)的鞏固和對(duì)自己的編程思想都有一定的好處,通過(guò)課程設(shè)計(jì)使我進(jìn)一步鞏固課堂上所學(xué)的理論知識(shí),深化理解和靈活掌握教學(xué)內(nèi)容,培養(yǎng)獨(dú)立思考問(wèn)題、分析問(wèn)題、解決實(shí)際問(wèn)題的動(dòng)手能力,使我了解到編譯原理與
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 編譯原理課程設(shè)計(jì)
- 編譯原理課程設(shè)計(jì)--編譯器
- 編譯原理課程設(shè)計(jì)報(bào)告
- 編譯原理課程設(shè)計(jì) (2)
- 編譯原理課程設(shè)計(jì)報(bào)告
- 編譯原理課程設(shè)計(jì)報(bào)告_編譯器
- 編譯原理課程設(shè)計(jì)報(bào)告 (2)
- 編譯原理課程設(shè)計(jì)詞法分析
- 編譯原理課程設(shè)計(jì)--詞法分析
- 編譯原理課程設(shè)計(jì)報(bào)告--編譯器實(shí)現(xiàn)
- 編譯原理課程設(shè)計(jì)---編譯器的實(shí)現(xiàn)
- 編譯原理課程設(shè)計(jì)報(bào)告-編譯程序構(gòu)造
- 編譯原理課程設(shè)計(jì)--- 編譯代碼生成器設(shè)計(jì)
- 編譯原理課程設(shè)計(jì)--c語(yǔ)言編譯器實(shí)現(xiàn)
- 編譯原理課程設(shè)計(jì)--c語(yǔ)言編譯器實(shí)現(xiàn)
- c語(yǔ)言編譯器實(shí)現(xiàn)-編譯原理課程設(shè)計(jì)
- 編譯原理課程設(shè)計(jì)--- 詞法分析程序
- 編譯原理課程設(shè)計(jì)---c語(yǔ)言編譯器的實(shí)現(xiàn)
- 編譯原理課程設(shè)計(jì)---簡(jiǎn)單編譯器的設(shè)計(jì)與實(shí)現(xiàn)
- 編譯原理課程設(shè)計(jì)____c語(yǔ)言編譯器的實(shí)現(xiàn)-
評(píng)論
0/150
提交評(píng)論