[转载] 预处理与预编译

预编译与预处理的区别是什么

原文地址

定义不同

  1. 预编译:预编译指的是在编译过程中对源代码进行的一些处理操作,例如头文件的包含、宏展开等。

  2. 预处理:预处理指的是在编译之前对源代码进行的一些文本替换操作,例如宏定义、条件编译等。

处理方式不同

  1. 预编译:预编译器会将源代码中使用的头文件的内容插入到源代码中,然后再进行编译。

  2. 预处理:预处理器会将源代码中的预处理指令替换为相应的内容,生成新的源代码文件。

发生时间不同

  1. 预编译:发生在编译过程中。

  2. 预处理:发生在编译之前。

目的不同

  1. 预编译:为了加快编译速度和减少编译错误,因为预编译器可以将头文件的内容缓存起来,避免重复编译。

  2. 预处理:为了方便程序员编写代码,提高代码的复用性和可维护性。

预编译简介

预编译是做些代码文本的替换工作。是整个编译过程的最先做的工作。预编译是做些代码文本的替换工作。处理以“#”开头的预编译指令,比如拷贝“#include”包含的文件代码,“#define”宏定义的替换,条件编译等,就是为编译做的预备工作的阶段。预编译指令指示了在程序正式编译前就由编译器进行的操作,可以放在程序中的任何位置。C编译系统在对程序进行通常的编译之前,首先进行预处理。并不是任何时候都需要预编译,如果总是使用不经常改动的大型代码体或者程序由多个模块组成,所有模块都使用一组标准的包含文件和相同的编译选项的时候,在这种情况下,可以将所有包含文件预编译为一个“预编译头”。

预处理简介

预处理(pre-treatment),是指在进行最后加工完善以前进行的准备过程,具体应用在不同的行业或领域,会有不同的解释。在一些程序设计语言中,预处理是preprocessing的翻译。

程序设计领域中,预处理一般是指在程序源代码被翻译为目标代码的过程中,生成二进制代码之前的过程。典型地,由预处理器(preprocessor)对程序源代码文本进行处理,得到的结果再由编译器核心进一步编译。这个过程并不对程序的源代码进行解析,但它把源代码分割或处理成为特定的单位——(用C/C++的术语来说是)预处理记号(preprocessing token)用来支持语言特性(如C/C++的宏调用)。

最常见的预处理是C语言和C++语言。ISO C和ISO C++都规定程序由源代码被翻译分为若干有序的阶段(phase),通常前几个阶段由预处理器实现。预处理中会展开以“#”起始的行,试图解释为预处理指令(preprocessing directive),其中ISO C/C++要求支持的包括#if/#ifdef/#ifndef/#else/#elif/#endif(条件编译)、#define(宏定义)、#include(源文件包含)、#line(行控制)、#error(错误指令)、#pragma(和实现相关的杂注)以及单独的#(空指令)。预处理指令一般被用来使源代码在不同的执行环境中被方便的修改或者编译。

预处理器在UNIX传统中通常缩写为PP,在自动构建脚本中C预处理器被缩写为CPP的宏指代。为了不造成歧义,C++(cee-plus-plus)经常并不是缩写为CPP,而改成CXX。

注意预处理常被错误地当作预编译(precompiling),事实上这是两个不同的概念。预处理尽管并不是ISO C/C++要求的单独阶段,但“预处理”这个术语正式地出现并参与构成其它术语,如C的预处理翻译单元(preprocessing translation unit)以及C/C++词法规则中预处理记号(prerprocessing-token)这个语法分类。预编译是一些编译器支持的特性,不是C/C++语言的特性或实现必须要求遵循的规则涉及到的内容,没有在ISO C/C++全文中出现。

-------------本文结束感谢您的阅读-------------

欢迎关注我的其它发布渠道