源文件在编译器中的处理过程

预处理:

1.只进行预处理操作 gcc -E demo.c > demo2.i 
  大于号的作用是把进行预处理操作后生成的.i文件放到大于号后面的文件里面,称作重定向。 经过预处理之后的文件后缀名为.i
 
2.预处理做的事情包括:头文件展开、宏替换、条件编译
   条件编译在实际应用中非常多,通过条件编译可以选择编译代码的一部分,是大段注释的技巧  例如:#if 1 & #if 0
   另外大段注释的技巧还有 /*   */
 
3.绝对路径 cd/user/include 是系统头文件目录
 
<stdio.h>:尖括号包含的是系统的头文件目录,如果找不到就报错
“stdio.h”:双引号下包含的头文件 ,先在当前的.c目录下找,找不到就到系统的头文件目录下找,再找不到就报错。 

编译:gcc -c demo.c
到编译这个步骤停止,编译后会生成demo.o文件 编译生成的目标文件后缀名是.o
 
编译阶段做的事情是语法检查、词法分析

汇编:gcc -s demo.c

运行到汇编截止,生成汇编文件demo.s   .s是汇编文件的后缀

链接:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个编译器的源代码是我原先为了完成编译原理实验课作业而写的,所以只具有教学价值,现在发出来和大家共享 ;-)<br/><br/>和网上流传的版本不同,它从文法开始,一直做到了符号表的实现. 想实现自己的编译器的话,只需在把Initializtion.h的文法修改为自己的即可.<br/><br/>工程结构:<br/>Initializtion.h 初始化文法,便于进一步进行分析,它为构造GRAMMAR类提供了信息.其默认非终极符用<>括上,修改时需要注意.<br/>Grammar.cpp Grammar.h 定义了文法GRAMMAR类,它通过initializtion.h的信息建立文法的内部表示。<br/>LL1_Analyser.cpp LL1_Analyser.h 定义了LL1分析器,即LL1_Analyser类.<br/>LL1_Recognizer.cpp LL1_Recognizer.h 为LL1语法分析驱动器,可以通过文法,TOKEN序列和LL1分析表,判定语法是否正确,同时驱动动作.<br/>Rec_Parse.cpp Rec_Pares.h 实现了递归下降分析器Rec_Parse类, 递归下降的思想和LL1驱动器一样,不过是把压栈改成调用自己,而把弹栈改成返回.<br/>Scanner.cpp Scanner.h 实现了词法分析器,可以将程序变为TOKEN序列. 扫描的源程序文件路径也在这里被定义(默认为.//demo.txt)<br/>Action.cpp Action.h 实现了语义栈的操作,_Action类定义了动作符号所对应的动作.<br/>SymTable.cpp SymTable.h 实现了符号表的建立和输出.<br/><br/>希望大家能通过该程序对STL和编译原理有更深刻的理解,Have Fun and Good Luck!<br/><br/> -- David.Morre
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值