对每个编译器给出了一方法,在保持与C和C++语言完全兼容的情况下,给出主机或操作系统专有的特征。
编译指示是机器或操作系统专有的,且对于每个编译器都是不同的。
#pragma para
其中:para为命令参数。
在编译信息输出窗口中输出相应的信息,这对于源代码信息的控制是非常重要的。其使用方法为:
#pragma message("消息文本")
当编译器遇到这条指令时就在编译输出窗口中将消息文本打印出来。
如果在程序中定义了许多宏,用于控制源代码版本,则有可能会忘记有没有正确的设置这些宏,此时可以用这条指令在编译的时候就进行检查。
假设希望判断有没有在源代码的什么地方定义了_X86这个宏,可以用下面的方法:
#ifdef _X86
#pragma message("_X86 macro activated!")
#endif
定义了_X86这个宏以后,应用程序在编译时就会在编译输出窗口里显示"_86 macro activated!"。就会知道有没有定义一些特定的宏了。
格式:
#pragma code_seg( ["section-name" [,"section-class"] ])
它能够设置程序中函数代码存放的代码段,当开发驱动程序的时候就会使用到它。
只要在头文件的最开始加入这条指令就能够保证头文件被编译一次,这条指令实际上在VC6中就已经有了,但是考虑到兼容性并没有太多的使用它。
表示预编译头文件到此为止,后面的头文件不进行预编译。BCB可以预编译头文件以加快链接的速度,但如果所有头文件都进行预编译又可能占太多磁盘空间,所以使用这个选项排除一些头文件。有时单元之间有依赖关系,比如单元 A 依赖单元 B,所以单元 B 要先于单元 A 编译。
可以用#pragma startup 指定编译优先级,如果使用了#pragma package(smart_init),BCB就会根据优先级的大小先后编译。
表示把*.dfm文件中的资源加入工程。*.dfm中包括窗体外观的定义。
不显示4507和34号警告信息 ,4385号警告信息仅报告一次,把164号警告信息作为一个错误。
pragma warning 支持的其它下格式:
#pragma warning( push ) 保存所有警告信息的现有的警告状态。
#pragma warning( push, n ) 保存所有警告信息的现有的警告状态,并且把全局警告等级设定为n(1-4)。
#pragma warning( pop ) 从栈中弹出最后一个警告信息,在入栈和出栈之间所作的一切改动取消。
该指令将一个注释记录放入一个对象文件或可执行文件中。
常用的lib关键字,可以帮我们连入一个库文件。如:
#pragma comment(lib, "comctl32.lib")
#pragma comment(lib, "vfw32.lib")
#pragma comment(lib, "wsock32.lib")激活循环|终止循环优化功能。
启用或者禁止:“变量已定义但未使用的”警告信息。