- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
汇编语言编译实验指导
实验一 源程序的输入和扫描实验内容:制一个源程序的输入、扫描程序,从文件中每次读入一行到输入缓冲区(可以用字符数组实现);然后从缓冲区中依次取出字符显示在屏幕上。从文件每次读入一行到输入缓冲区的功能(可以用字符数组实现)用一个子程序实现。实验目的:从文件中读入到输入缓冲区采用一个子程序实现的形式程序判断源文件是否为NULL如果是则输出错误提示如果不是则进入循环调用子程序readbuffer()每次读入一个字符给字符变量如果字符变量的内容不是回车符则把字符变量的内容存入数组buffer()然后读入下一字符再判断再存入数组直到一行全存入数组,然后返回主程序用输出语句输出刚才存入数组的一行字符果没有到文件尾,则重复第(2)步直到文件结束则退出主程序完成任务输入、扫描程序main()
{
int a,b ,c;
a = 10; b=20;
c=a+b;
}
??自编源程序:?输入、扫描程序源代码: ?//程序开始: # includestdio.h# includestdlib.h
# includeconio.h
//声明头文件int?i;
FILE?*fp;
char?buffer[256];
//声明变量int?readbuffer() //读字符子程序开始{
int?j=0;
char?ch;
//声明变量while(j256)
{
ch=fgetc(fp);
if?(ch==\n)?
{
i=j; return?0;
} //
buffer[j]=ch; //保存字符
++j; //记录字符个数
}
return?1;
} //子程序结束main() //main()开始{
if((fp=fopen(e:\\a.c,r))==NULL)
{
printf(THE?FILE?DOESN’T?OPEN!);exit(0);}
while(!feof(fp))
{
int?j;
j=0;
readbuffer();
while(ji)
{
printf(%c,buffer[j]);
j++;
}
printf(\n);
getch();
}
fclose(fp);
getch();
} //main()结束//程序结束源文件:\\a.c内容为:main()
{
int?sum=0,i;
float?k;
scanf?(%f?plese?input?(0-100)?to?total!,k)
?
for(i=0;ik;i++)
sum?=sum+i;
}
运行自编的输入扫描程序,检查输出结果必须与上面输入的源文件中的代码相同。
[实验报告]:
1、写出调试程序出现的问题及解决的方法。
2、写实验报告及程序清单。
3、报告给出测试的结果。
4、实验小结
实验二 无符号数的有限自动机的实现
学时数:4
[实验内容]:
无符号数的有限自动机的实现。利用状态表和有限自动机的运行原理编制程序,使得程序能够识别一个输入串是否为一个无符号定点实数。
[实验题目]:
1、理解有限自动机的作用;进一步理解自动机理论。
用状态图和状态表表示有限自动机;
3、以程序实现有限自动机的运行过程;掌握文法转换成自动机的技术及有穷自动机实现的方法。
[实验要求]:
设计要求:利用状态图或状态表相关理论,利用有限自动机理论。
功能要求:输入一个单行无空格的字符串(以“#”号结束),如果该字符串是一个合法的输入,则显示“接受”,否则显示“不接受”。
输入/输出示例(以无符号定点实数为例):
输入:“3.14”,输出:“接受”;
输入:“3.1.4”,输出:“不接受”;
输入:“3ab”,输出:“不接受”。
[实验提示]:
1、无符号数的BNF描述如下:
1.无符号数 ( d 余留无符号数 | . 十进制数 | e 指数部分
2.余留无符号数 ( d 余留无符号数 | . 十进制数 | e 指数部分 | ε
3.十进制小数 ( d 余留十进制小数
4.余留十进制小数 e 指数部分 | d 余留十进制小数 | ε
5.指数部分 ( d 余留整指数数 | + 整指数 | - 整指数
6.整指数 ( d 余留整指数数
7.余留整指数数 ( d 余留整指数数 | ε
2、将G[无符号数]文法转换成有限自动机 见图1。
图1
3、构造状态矩阵;将有限自动机的状态S1 S2 ……Sn及输入的字a1 a2 ……am 构成一个n*m的矩阵。
1)根据状态矩阵设计出一个词法分析程序识别无符号数。
2)扫描无符号数,根据文法给出无符号数出错的位置。
[实验报告]:
1、写出无符号数词法分析的思想。
2、画出算法流程图。
3、写出调试
文档评论(0)