编译原理 | 实验任务一:在计算机上实现PL0语言的编译程序

代码及结果:task1
任务二博客:编译原理 | 实验任务二:扩展Read和Write语句

1 找到PASCAL编译系统

下载安装free pascal,设置环境变量,然后用vscode编辑。
参考资料:在windows命令行下编译运行Pascal程序


2 在PASCAL系统上运行PL0编译程序,需要对PL0编译程序作一些修改、调试

1.改格式(缩进、注释)

2.符号修改

~ -> not//~这个符号打不出来,反正就是非的意思

//procedure和object在pascal中是关键字,所以分别使用proceduree和objectt替代
object -> objectt;
procedure -> proceduree;

cc—1 -> cc-1;
↑ -> ^;
≤ -> <=;
≠ -> <>

3. 注释掉不必要的(其实是报错的)语句,如

在这里插入图片描述
直接注释掉(或删掉)
在这里插入图片描述

4.标号99原来是用于退出程序的,由于不支持跨过程的跳转,所以直接退出
在这里插入图片描述

//procedure  gen(x : fct; y, z : integer);
    	if cx > cxmax then 
        begin 
            write('PROGRAM TOO LONG'); 
            exit
            //goto 99
        end;
//procedure  getch ; 

        if eof(fin) then {
   如果已到文件尾}
        begin
            writeln('PROGRAM INCOMPLETE'); 
            exit;
            //goto 99
        end;

//主程序
//99 : writeln
    writeln;

5.现在暂时没有错误了
在这里插入图片描述


3 建立输入文件和输出文件

在输入文件中存放PL0源程序
在这里插入图片描述
在输出文件中存放PL0源程序被编译后产生的中间代码和运行数据
在这里插入图片描述


4 通过输入文件输入PL0源程序,在输出文件中产生源程序的中间代码, 然后运行该中间代码, 在输出文件中产生运行数据

1.增加变量fin和fout,以命令行形式读取和写入文件
在这里插入图片描述

//{全局变量定义}
//var
fin : text;       {
   源代码文件}
fout : text;      {
   输出文件}
...

begin  {
   主程序}
    assign(fin,paramstr(1));
    assign(fout,paramstr(2));	{
   将命令行参数str变量赋值给文件变量}
    reset(fin);
    rewrite(fout);	{
   打开输入输出文件}
    ...
    //99 : writeln
    writeln;
    close(fin);
    close(fout);

2.exit时关闭文件

//getch
		begin
            writeln('PROGRAM INCOMPLETE'); 
            close(fin);
            close(fout);
            exit;
            //goto 99
        end;

//gen
		begin 
            write('PROGRAM TOO LONG'); 
            close(fin);
            close(fout);
            exit
            //goto 99
        end;

3.将所有input改成fin,有read的地方都改成从fin文件读入,有write的地方都改成写到fout文件:

//getch
	if eof(fin) then {
   如果已到文件尾}
	...
	while not eoln(fin) do {
   如果不是行末}
        begin
            ll := ll + 1; {
   将行缓冲区的长度+1}
            read(fin, ch); {
   从源文件中读取一个字符到ch中}
            write(fout, ch);{
   输出ch到输出文件中}
            line[ll] := ch  {
   把这个字符放到当前行末尾}
        end;
        writeln(fout); {
   换行}
        readln(fin);{
   从源文件下一行开始读取}
        ll := ll + 1; {
   将行缓冲区的长度+1}
        line[ll] := ' ' 
  • 3
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来给你讲一下如何使用C++语言编写PL/0编译程序的语法分析程序。 首先,我们需要了解PL/0语言的语法规则,这里简单介绍一下: 1. 程序由常量声明、变量声明、过程声明和语句组成; 2. 常量声明以const开始,后跟一个标识符和一个等号,再后面是一个整数; 3. 变量声明以var开始,后跟一个或多个标识符,用逗号分隔; 4. 过程声明以procedure开始,后跟一个标识符和一个分号,再后面是一个块; 5. 语句包括赋值语句、条件语句、循环语句和调用语句,以及读写语句和复合语句; 6. 赋值语句以标识符开始,后跟一个等号和一个表达式; 7. 条件语句以if开始,后跟一个条件表达式、then和一个语句; 8. 循环语句以while开始,后跟一个条件表达式和do,再后面是一个语句; 9. 调用语句以call开始,后跟一个标识符; 10. 读语句以read开始,后跟一个左括号和一个或多个标识符,用逗号分隔,再跟一个右括号; 11. 写语句以write开始,后跟一个左括号和一个或多个表达式,用逗号分隔,再跟一个右括号; 12. 复合语句以begin开始,后跟一个或多个语句,用分号分隔,再跟一个end。 了解了PL/0的语法规则之后,我们就可以开始编写语法分析程序了。具体步骤如下: 1. 定义PL/0语言的语法结构体,包括常量、变量、过程、语句等; 2. 定义词法分析器,将输入的PL/0代码转换成一个个词法单元(token); 3. 编写递归下降分析函数,根据语法规则递归地分析每个词法单元,并生成语法树; 4. 在递归下降分析函数中,需要定义一个函数来处理每个语法规则,例如处理常量声明的函数、处理变量声明的函数等; 5. 在语法分析程序中,还需要定义一些辅助函数,例如查找符号表、生成中间代码等; 6. 最后,将语法分析程序与词法分析器、中间代码生成器等组合起来,完成PL/0编译程序编写。 以上是编写PL/0编译程序的语法分析部分的大致流程,具体实现还需要根据实际情况进行调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值