下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1常见的预处理功能: 预处理器的主要作用就是把通过预处理的内建功能对一个资源进行等价替换,最常见的预处理有:文件包含,条件编译、布局控制和宏替换4种。 文件包含:#include 是一种最为常见的预处理,主要是做为文件的引用组合源程序正文。 条件编译:#if,#ifndef,#ifdef,#endif,#undef等也是比较常见的预处理,主要是进行编译时进行有选择的挑选,注释掉一些指定的代码,以达到版本控制、防止对文件重复包含的功能。 布局控制:#progma,这也是我们应用预处理的一个重要方面,主要功能是为编译程序提供非常规的控制流信息。宏替换: #define,这是最常见的用法,它可以定义
2、符号常量、函数功能、重新命名、字符串的拼接等各种功能。2下面我们看一下常见的预处理指令: #define 宏定义 #undef 未定义宏 #include 文本包含 #ifdef 如果宏被定义就进行编译 #ifndef 如果宏未被定义就进行编译 #endif 结束编译块的控制 #if 表达式非零就对代码进行编译 #else 作为其他预处理的剩余选项进行编译 #elif 这是一种#else和#if的组合选项 #line 改变当前的行数和文件名称 #error 输出一个错误信息#pragma 为编译程序提供非常规的控制流信息3下面我们对这些预处理进行一一的说明,考虑到宏的重要性和繁琐性,我们把它放
3、到最后讲。 文件包含指令: 这种预处理使用方式是最为常见的,平时我们编写程序都会用到,最常见的用法是: #include /标准库头文件 #include /旧式的标准库头文件 #include IO.h /用户自定义的头文件 #include /file.h /UNIX下的父目录下的头文件 #include /usr/local/file.h /UNIX下的完整路径 #include file.h /Dos下的父目录下的头文件 #include usrlocalfile.h /Dos下的完整路径 这里面有2个地方要注意: 1)我们用还是 我们主张使用,而不是,为什么呢?我想你可能还记得我曾经
4、给出过几点理由,这里我大致的说一下:首先,h格式的头文件早在98年9月份就被标准委员会抛弃了,我们应该紧跟标准,以适合时代的发展。其次,iostream.h只支持窄字符集,iostream则支持窄/宽字符集。 还有,标准对iostream作了很多的改动,接口和实现都有了变化。最后,iostream组件全部放入namespace std中,防止了名字污染。 2)和io.h的区别? 其实他们唯一的区别就是搜索路径不同: 对于#include ,编译器从标准库路径开始搜索 对于#include io.h ,编译器从用户的工作路径开始搜索 编译控制指令: 这些指令的主要目的是进行编译时进行有选择的挑选
5、,注释掉一些指定的代码,以达到版本控制、防止对文件重复包含的功能。 使用格式,如下: 1)#ifdef identifier your code #endif 如果identifier为一个定义了的符号,your code就会被编译,否则剔除 2) #ifndef identifier your code #endif 如果identifier为一个未定义的符号,your code就会被编译,否则剔除 3) #if expression your code #endif 如果expression非零,your code就会被编译,否则剔除 4) #ifdef identifier your c
6、ode1 #else your code2 #endif 如果identifier为一个定义了的符号,your code1就会被编译,否则yourcode2就会被编译 5) #if expressin1 your code1 #elif expression2 /呵呵,elif your code2 #else your code3 #enif 如果epression1非零,就编译your code1,否则,如果expression2非零,就编译your code2,否则,就编译your code34.其他预编译指令 除了上面我们说的集中常用的编译指令,还有3种不太常见的编译指令:#line、
7、#error、#pragma,我们接下来就简单的谈一下。 #line的语法如下: #line number filename 例如:#line 30 a.h 其中,文件名a.h可以省略不写。 这条指令可以改变当前的行号和文件名,例如上面的这条预处理指令就可以改变当前的行号为30,文件名是a.h.初看起来似乎没有什么用,不过,他还是有点用的,那就是用在编译器的编写中,我们知道编译器对C+源码编译过程中会产生一些中间文件,通过这条指令,可以保证文件名是固定的,不会被这些中间文件代替,有利于进行分析。 #error语法如下: #error info 例如: #ifndef UNIX #error T
8、his software requires the UNIX OS. #endif 这条指令主要是给出错误信息,上面的这个例子就是,如果没有在UNIX环境下,就会输出This software requires the UNIX OS.然后诱发编译器终止。所以总的来说,这条指令的目的就是在程序崩溃之前能够给出一定的信息。 #pragma是非统一的,他要依靠各个编译器生产者,例如,在SUN C+编译器中: / 把name和val的起始地址调整为8个字节的倍数 #progma align 8 (name, val) char name9; double val; /在程序执行开始,调用函数MyFu
9、nction #progma init (MyFunction)5.预定义标识符 为了处理一些有用的信息,预处理定义了一些预处理标识符,虽然各种编译器的预处理标识符不尽相同,但是他们都会处理下面的4种: _FILE_ (前面的下划线是两个)正在编译的文件的名字 _LINE_ 正在编译的文件的行号 _DATE_ 编译时刻的日期字符串,例如: 25 Dec 2000 _TIME_ 编译时刻的时间字符串,例如: 12:30:55 例如:coutThe file is :_FILE_! The lines is:_LINE_endl;6.预处理何去何从 如何取代#include预处理指令,我们在这里就不再一一讨论了。C+并没有为#include提供替代形式,但是namespace提供了一种作用域机制,它能以某种方式支持组合,利用它可以改善#include的行为方式,但是我们还是无法取代#include. #progma应该算是一个可有可无的预处理指令,按照C+之父Bjarne的话说,就是:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论