编译原理实验:源程序预处理

简介: 编译原理实验:源程序预处理

一:实验目的

对源程序进行预处理(函数实现、该函数以后还要用到;输入是源程序,输出是预处理过的程序)。

二:实验内容

对源程序进行预处理、去掉空格、跳格、回车、换行、注释等。

三:实验要求

从文本文件读入源代码文本字符串、预处理结束后写入另一个文本文件中。

四:实验过程

1.实验步骤

(1)删除代码中的空格、跳格、换行、回车

void del_space_tab_lineFeed_enter(char *str) {
   
   
    char s[1000];            // 存储输入文本
    int i = 0;        
    int point = 0, next = 0;

    strcpy(s,str);            // 将输入文本的内容复制到s字符数组中

    while(s[point] != '\0') {
   
   
        if(s[point] == ' ' || s[point] == '\n' || s[point] == '\r' || s[point] == '\t') {
   
   
            // 当前下标是空格,next下标加1,判断后面的是否为待删除内容,直到不是
            next = point + 1;
            while(s[next] == ' ' || s[next] == '\n' || s[next] == '\r'|| s[next] == '\t') {
   
   
                next++;
            }
            point = next;
        } else {
   
   
            // 当前下标不是待删除内容,让当前的str[i]等于s[point],使得str中的内容恒不为待删除内容
            str[i] = s[point];
            i++;
            point++;
        }
    }
    while(str[i++] != '\0')
        str[i-1] = '\0';
}

(2)删除注释

//删除文档里的注释
void del_comments(char *str){
   
   
    int i;
    for(i=0; str[i] != EOF; i++){
   
   
        if(str[i] == '/' && str[i+1] == '/') {
   
   
            str[i] = '\0';
            str[i+1] = '\0';
            break;
        }
    }
}

(3)主程序

void main() {
   
   
    char str[1000];
    char ss[99] = " ";
    FILE *fr, *fw;
    fr = fopen("input.txt", "r");        // 读取文档
    fw = fopen("output.txt", "w");        // 存入文档
    while(fgets(str, 99, fr) != NULL){
   
       // 对文档里的字符进行按行处理
        del_comments(str);                // 删除注释
        strcat(ss, str);
    }
    // 在回车和换行操作结束后,字符串与字符串之间可能会有空格,
    // 因此将所有的字符串合并成一个大字符串再进行一次空格删除的处理
    printf("%s\n", ss);
    del_space_tab_lineFeed_enter(ss);
    printf("%s", ss);
    fputs(ss, fw);        //存入文档
    fclose(fr);            //关闭文档
    fclose(fw);
    printf("\n");
    return;
}

(4)代码整合

#include<stdio.h>
#include<string.h>

void del_space_tab_lineFeed_enter(char *str) {
   
   
    char s[1000];            // 存储输入文本
    int i = 0;        
    int point = 0, next = 0;

    strcpy(s,str);            // 将输入文本的内容复制到s字符数组中

    while(s[point] != '\0') {
   
   
        if(s[point] == ' ' || s[point] == '\n' || s[point] == '\r' || s[point] == '\t') {
   
   
            // 当前下标是空格,next下标加1,判断后面的是否为待删除内容,直到不是
            next = point + 1;
            while(s[next] == ' ' || s[next] == '\n' || s[next] == '\r'|| s[next] == '\t') {
   
   
                next++;
            }
            point = next;
        } else {
   
   
            // 当前下标不是待删除内容,让当前的str[i]等于s[point],使得str中的内容恒不为待删除内容
            str[i] = s[point];
            i++;
            point++;
        }
    }
    while(str[i++] != '\0')
        str[i-1] = '\0';
}

//删除文档里的注释
void del_comments(char *str){
   
   
    int i;
    for(i=0; str[i] != EOF; i++){
   
   
        if(str[i] == '/' && str[i+1] == '/') {
   
   
            str[i] = '\0';
            str[i+1] = '\0';
            break;
        }
    }
}

void main() {
   
   
    char str[1000];
    char ss[99]=" ";
    FILE *fr, *fw;
    fr = fopen("input.txt", "r");        // 读取文档
    fw = fopen("output.txt", "w");        // 存入文档
    while(fgets(str, 99, fr) != NULL){
   
       // 对文档里的字符进行按行处理
        del_comments(str);                // 删除注释
        strcat(ss, str);
    }
    // 在回车和换行操作结束后,字符串与字符串之间可能会有空格,
    // 因此将所有的字符串合并成一个大字符串再进行一次空格删除的处理
    printf("%s\n",ss);
    del_space_tab_lineFeed_enter(ss);
    printf("%s",ss);
    fputs(ss,fw);//存入文档
    fclose(fr);//关闭文档
    fclose(fw);
    printf("\n");
    return;
}

2.实验结果记录

(1)输入文本

#include <studio.h>

// 这是一个源程序
void main(){
   
       
  print("Hello\nWorld\n\rI'm\tfocus");  
  return 0;
}

(2)运行结果

编译原理实验:源程序预处理运行结果

(3)输出文本

#include<studio.h>voidmain(){print("Hello\nWorld\n\rI'm\tfocus");return0;}
相关文章
|
6天前
|
人工智能 自然语言处理 机器人
AI也会"三思而后答"?揭秘Self-RAG智能检索术
遇到AI胡说八道怎么办?Self-RAG就像给AI装了个"思考开关",让它知道什么时候该查资料、什么时候该独立思考,还能自我评估答案靠不靠谱。6步智能决策机制,让AI回答又准又稳!#人工智能 #RAG技术 #智能检索 #AI应用
|
9月前
|
机器学习/深度学习 算法 关系型数据库
强化学习:动态规划求解最优状态价值函数——手把手教你入门强化学习(四)
本文介绍了基于模型的强化学习算法,重点讲解动态规划(DP)。动态规划通过分解问题为子问题求解状态价值函数,利用贝尔曼期望方程迭代更新。其核心性质包括最优子结构和重叠子问题,适用于已知转移概率和奖励的MDP场景。文章回顾了前期强化学习基础,并展望了后续内容如蒙特卡罗法。适合初学者系统了解强化学习算法原理与应用。
374 7
|
定位技术
ArcGIS投影:地理坐标系转为投影坐标系
本文介绍在ArcMap软件中,对矢量图层或栅格图层进行投影(即将地理坐标系转为投影坐标系)的原理与操作方法~
1644 1
ArcGIS投影:地理坐标系转为投影坐标系
|
前端开发 搜索推荐 JavaScript
如何成功完成一个Java项目答辩
如何成功完成一个Java项目答辩
378 1
|
存储 前端开发 Java
Java后端如何进行文件上传和下载 —— 本地版(文末配绝对能用的源码,超详细,超好用,一看就懂,博主在线解答) 文件如何预览和下载?(超简单教程)
本文详细介绍了在Java后端进行文件上传和下载的实现方法,包括文件上传保存到本地的完整流程、文件下载的代码实现,以及如何处理文件预览、下载大小限制和运行失败的问题,并提供了完整的代码示例。
5359 2
|
NoSQL 关系型数据库 Redis
高可用和性能:基于ACK部署Dify的最佳实践
本文介绍了基于阿里云容器服务ACK,部署高可用、可伸缩且具备高SLA的生产可用的Dify服务的详细解决方案。
|
存储 前端开发 Java
[java后端研发]——文件上传与下载(2种方式)
[java后端研发]——文件上传与下载(2种方式)
725 3
|
Linux 数据安全/隐私保护
如何在 Fedora 38 中为用户添加、删除和授予 Sudo 权限?
如何在 Fedora 38 中为用户添加、删除和授予 Sudo 权限?
803 0
如何在 Fedora 38 中为用户添加、删除和授予 Sudo 权限?
|
分布式计算 资源调度 安全
Hadoop停止所有Hadoop服务
【7月更文挑战第20天】
484 2
|
Java C++ 开发者
线程创建的终极对决:Thread 类 VS Runnable 接口,你站哪边?
【6月更文挑战第19天】在Java多线程编程中,通过`Thread`类直接继承或实现`Runnable`接口创建线程各有优劣。`Thread`方式简洁但不灵活,受限于Java单继承;`Runnable`更灵活,适合资源共享和多接口实现,提高代码可维护性。选择取决于项目需求和设计原则,需权衡利弊。
254 1

热门文章

最新文章