预处理

从源文件到可执行文件的4个步骤:预处理、汇编、编译、链接形成可执行文件


预处理指令是指源文件中以#号开头的代码行。
#号必须是该行除了任何空白字符外的第一个字符。
#后是指令关键字,在关键字和#号之间允许存在任意个数的空白字符。整行语句构成了一条预处理指令,
该指令将在编译器进行编译之前对源代码做某些转换。
指令             用途
 #             空指令,无任何效果
 #include       包含一个源代码文件
 #define        定义宏
 #undef         取消已定义的宏
 #if          如果给定条件为真,则编译下面代码
 #ifdef         如果宏已经定义,则编译下面代码
 #ifndef        如果宏没有定义,则编译下面代码
 #elif          如果前面的#if给定条件不为真,当前条件为真,则编译下面代码
 #endif         结束一个#if……#else条件编译块
 #error         停止编译并显示错误信息
 #else          条件编译的否则选项
 #error         指令将使编译器显示一条错误信息,然后停止编译。
 #line          指令可以改变编译器用来指出警告和错误信息的文件号和行号。
 #pragma        指令没有正式的定义。编译器可以自定义其用途。典型的用法是禁止或允许某些烦人的警告信息。


文件包含
在程序中包含头文件有两种格式:
#include <my.h>
#include "my.h"


第一种方法是用尖括号把头文件括起来。这种格式告诉预处理程序在编译器自带的或外部库的头文件中搜索被包含的头文件。
 
第二种方法是用双引号把头文件括起来。这种格式告诉预处理程序在当前被编译的应用程序的源代码文件中搜索被包含的头文件,如果找不到,再按一种方法搜索。
 
采用两种不同包含格式的理由在于,编译器是安装在公共子目录下的,而被编译的应用程序是在它们自己的私有子目录下的。一个应用程序既包含编译器提供的公共头文件,也包含自定义的私有头文件。采用两种不同的包含格式使得编译器能够在很多头文件中区别出头文件的位置。 


那什么是编译前的预处理呢? 
预处理过程读入源代码,检查包含预处理指令的语句和宏定义,
并对源代码进行相应的转换。预处理过程还会删除程序中的注释
和多余的空白字符。
功能主要包括:
宏定义,文件包含,条件编译三部分。
分别对应宏定义命令,文件包含命令,条件编译命令 三部分实现。生成".i"后缀的文件


编译过程中的汇编是什么意思呢?就是把c语言翻译成汇编语言的意思(.s)。
编译过程中的编译就是把汇编语言翻译成机器语言的意思。也就是说.o或.obj为后缀的对象文件(目标文件)已经是机器语言了,是可以被计算机所理解的了。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值