发新帖我要提问
123
返回列表
打印
[牛人杂谈]

C语言预处理命令有哪些

[复制链接]
楼主: zhuomuniao110
手机看帖
扫描二维码
随时随地手机跟帖
41
最小化重建( Minimal Rebuild ) Visual C++的最小化重建功能要求编译程序创建并保存需要大量磁盘空间的C++类依赖信息。为了节省磁盘空间,你能够在你不需要收集依赖信息时使用#pragma component(minrebuild,off),例如,没有改变过头文件。在未修改过的类之后插入#pragma component(minrebuild,on)重新打开依赖信息。 详见Enable Minimal Rebuild(/Gm)编译程序选项。 9 data_seg #pragma data_seg( ["section-name"[, "section-class"] ] ) 指定数据的默认段。例如: #pragma data_seg( "MY_DATA" ) 导致在#pragma语句后分配的数据保存在一个叫做MY_DATA的段中。 用data_seg编译指示分配的数据不包含任何关于其位置的信息。 第二个参数section-class是用于兼容2.0版本以前的Visual C++的,现在将忽略它。 10 function #pragma function( function1 [, function2, ...] ) 指定必须生成对编译指示中参数列表内函数的调用。如果你使用intrinsic编译指示(或者/Oi)来告诉编译程序生成内含函数(内含函数如同嵌入代码一样生成,不作为一个函数调用),你能够用function编译指示显式地强迫函数调用。当遇到一个function编译指示,它将在其后面遇到的第一个包含有内含函数的函数定义处生效。其持续作用到源文件的尾部或者出现对同一个内含函数指定intrinsic编译指示。function编译指示只能用于函数外——在全局层次。 为了列出具有内含形式的函数表,参见#pragma intrinsic。 11 hdrstop #pragma hdrstop [( "filename" )] 控制预编译头文件的工作方式。filename是要使用或者创建(依赖于是否指定了/Yu或/Yc)预编译头文件的名字。如果 filename不包括一个指定路径,将假定预编译头文件和源文件处于同一个目录中。当指定自动预编译头文件选项/YX时,所有指定的文件名将被忽略。 如果有/YX或者/Yc选项,而且C或C++文件包含了一个hdrstop编译指示时,编译程序保存编译指示之前的编译状态。编译指示之后的编译状态不被保存。 hdrstop编译选项不能出现在一个头文件内。它只能出现在源文件的文件级,它也不能出现在任何数据或者函数的说明或定义之中。 注意,除非指定没有文件名的/YX选项或者/Yu或/Yc选项,否则hdrstop编译指示将被忽略。 用一个文件名命名要保存编译状态的预编译头文件。在hdrstop和filename之间的空格是可选的。在hdrstop编译指示中的文件名是一个字符串,这样它服从于C或C++的字符串规则。特别的,你必须像下面例子里面显示的用引号括起来。 #pragma hdrstop( "c:\projects\include\myinc.pch" ) 预编译头文件的文件名按照如下规则决定,按照优先次序: /Fp编译程序选项的参数; 由#pragma hdrstop的filename参数; 原文件名的基本文件名加上.PCH扩展名。 12 include_alias #pragma include_alias( "long_filename", "short_filename" ) #pragma include_alias( , ) 指定作为long_filename别名的short_filename。一些文件系统允许超出8.3FAT文件系统限制的长头文件名。编译程序不能简单地将长文件名截断为8.3名字,因为长头文件名的前8个字符可能不是唯一的。无论何时编译程序遇到long_filename串,它代替short_filename,并且用short_filename搜索头文件。这个编译指示必须出现在相应的#include指示之前。例如: // First eight characters of these two files not unique. #pragma include_alias( "AppleSystemHeaderQuickdraw.h", "quickdra.h" ) #pragma include_alias( "AppleSystemHeaderFruit.h", "fruit.h" ) #pragma include_alias( "GraphicsMenu.h", "gramenu.h" ) #include "AppleSystemHeaderQuickdraw.h" #include "AppleSystemHeaderFruit.h" #include "GraphicsMenu.h" 这个别名在搜索时精确匹配,包括拼写和双引号、尖括号。include_alias编译指示在文件名上执行简单的字符串匹配,不进行其它的文件名验证。例如,给出下列指示: #pragma include_alias("mymath.h", "math.h") #include "./mymath.h" #include "sys/mymath.h" 并不执行别名替代,因为头文件名字符串没有精确匹配。另外,在/Yu,/Yc和/YX编译程序选项,或hdrstop编译指示中作为参数的头文件名不被替换。例如,如果你的源文件包含下列指示: #include 相应的编译程序选项必须是: /YcAppleSystemHeaderStop.h 你能够用include-_alias编译指示将任何头文件映射到其它文件。例如: #pragma include_alias( "api.h", "c:\version1.0\api.h" ) #pragma include_alias( , ) #include "api.h" #include 不要混淆用双引号和尖括号括起来的文件名。例如,给出上面的#pragma include_alias指示时,在下面的#include指示中编译程序不执行替换。 #include #include "stdio.h" 还有,下面的指示将产生一个错误: #pragma include_alias(, "header.h") // Error 注意,在错误信息中报告的文件名,或者预定义宏__FILE__的值,是执行替换以后的文件名。例如,在下列指示之后: #pragma include_alias( "VeryLongFileName.H", "myfile.h" ) #include "VeryLongFileName.H" 文件VeryLongFileName.H产生下列错误信息: myfile.h(15) : error C2059 : syntax error 还要注意的是不支持传递性。给出下面的指示: #pragma include_alias( "one.h", "two.h" ) #pragma include_alias( "two.h", "three.h" ) #include "one.h" 编译程序将搜索two.h而不是three.h。 被 管理人员 屏蔽帖子

使用特权

评论回复
42
玛尼玛尼哄| | 2016-4-30 12:20 | 只看该作者
您的回复 7 comment #pragma comment( comment-type [, commentstring] ) 将描述记录安排到目标文件或可执行文件中去。comment-type是下面说明的五个预定义标识符中的一个,用来指定描述记录的类型。可选的commentstring是一个字符串文字值用于为一些描述类型提供附加的信息。因为commentstring是一个字符串文字值,所以它遵从字符串文字值的所有规则,例如换码字符、嵌入的引号(")和联接。 7-1 compiler 在目标文件中放置编译程序名和版本号。该描述记录被连接程序忽略。如果你为这个记录类型提供一个commentstring参数,编译程序将生成一个警告。 7-2 exestr 将commentstring放置到目标文件中去。在连结时,这个字符串再被放到可执行文件去中。当可执行文件被装载时这个字符串不会被装入内存,然而,它可以被一个能够在文件中搜索可打印字符串的程序找到。该描述记录的一个用处是在可执行文件中嵌入版本号或者类似的信息。 7-3 lib 将一个库搜索记录放置到目标文件中去。该描述类型必须有包含你要连接程序搜索的库名(和可能的路径)的commentstring参数。因为在目标文件中该库名先于默认的库搜索记录,所以连接程序将如同你在命令行输入这些库一样来搜索它们。你可以在一个源文件中放置多个库搜索记录,每个记录将按照它们出现在源文件中的顺序出现在目标文件中。 7-4 linker 在目标文件中放置连接程序选项。你可以用这个描述类型指定连接程序选项来代替在Project Setting对话框中Link页内的选项。例如,你可以指定/include选项以强迫包含一个符号: #pragma comment(linker, "/include:__mySymbol") 7-5 user 在目标文件中包含一个普通描述记录。commentstring参数包含描述的文本。该描述记录将被连接程序忽略。 下面的编译指示导致连接程序在连接时搜索EMAPI.LIB库。连接程序首先在当前工作目录然后在LIB环境变量指定的路径中搜索。 #pragma comment( lib, "emapi" ) 下面的编译指示导致编译程序将其名字和版本号放置到目标文件中去。 The following pragma causes the compiler to place the name and version number of the compiler in the object file: #pragma comment( compiler ) 注意,对于具有commentstring参数的描述记录,你可以使用其它用作字符串文字量的宏来提供宏扩展为字符串文字量。你也能够联结任何字符串文字量和宏的组合来扩展成为一个字符串文字量。例如,下面的语句是可以接受的: #pragma comment( user, "Compiled on " __DATE__ " at " __TIME__ ) 8 component #pragma component( browser, { on | off }[, references [, name ]] ) #pragma component( minrebuild, on | off ) 从源文件内控制浏览信息和依赖信息的收集。 8-1 浏览信息( Browser ) 你可以将收集打开或关闭,你也可以指定收集时忽略特别的名字。 使用on或off在编译指示以后控制浏览信息的收集。例如: #pragma component(browser, off) 终止编译程序收集浏览信息。 注意,为了用这个编译指示打开浏览信息的收集,必须先从Project Setting对话框或者命令行允许浏览信息。 references选项可以有也可以没有name参数。使用没有name参数的references选项将打开或者关闭引用信息的收集(然而继续收集其它浏览信息)。例如: #pragma component(browser, off, references) 终止编译程序收集引用信息。 使用有name和off参数的references选项将阻止从浏览信息窗口中出现引用到的名字。用这个语法将忽略你不感兴趣的名字和类型从而减少浏览信息文件的大小。例如: #pragma component(browser, off, references, DWORD) 从这一点以后忽略DWORD的引用。你能够用on恢复DWORD的引用收集: #pragma component(browser, on, references, DWORD) 这是唯一的方法可以恢复收集指定名字的引用,你必须显式地打开任何你关闭的名字。 为了防止预处理程序扩展名字(就像扩展NULL到0),用引号括起来: #pragma component(browser, off, references, "NULL") 被 管理人员 屏蔽帖子

使用特权

评论回复
43
玛尼玛尼哄| | 2016-4-30 12:21 | 只看该作者
您的回复 *仅用于C++编译程序。1 alloc_text #pragma alloc_text( "textsection", function1, ... )命名特别定义的函数驻留的代码段。该编译指示必须出现在函数说明符和函数定义之间。alloc_text编译指示不处理C++成员函数或重载函数。它仅能应用在以C连接方式说明的函数——就是说,函数是用extern "C"连接指示符说明的。如果你试图将这个编译指示应用于一个具有C++连接方式的函数时,将出现一个编译程序错误。由于不支持使用__based的函数地址,需要使用alloc_text编译指示来指定段位置。由textsection指定的名字应该由双引号括起来。alloc_text编译指示必须出现在任何需要指定的函数说明之后,以及这些函数的定义之前。在alloc_text编译指示中引用的函数必须和该编译指示处于同一个模块中。如果不这样做,使以后一个未定义的函数被编译到一个不同的代码段时,错误会也可能不会被捕获。即使程序一般会正常运行,但是函数不会分派到应该在的段。alloc_text的其它限制如下:它不能用在一个函数内部。它必须用于函数说明以后,函数定义以前。2 auto_inline #pragma auto_inline( [{on | off}] )当指定off时将任何一个可以被考虑为作为自动嵌入扩展候选的函数排除出该范围。为了使用auto_inline编译指示,将其紧接着写在一个函数定义之前或之后(不是在其内部)。该编译指示将在其出现以后的第一个函数定义开始起作用。auto_inline编译指示对显式的inline函数不起作用。3 bss_seg #pragma data_seg( ["section-name"[, "section-class"] ] )为未初始化数据指定缺省段。data_seg编译指示除了工作于已初始化数据而不是未初始化的以外具有一样的效果。在一些情况下,你能使用bss_seg将所有未初始化数据安排在一个段中来加速你的装载时间。#pragma bss_seg( "MY_DATA" )将导致把#pragma语句之后的未初始化的数据安排在一个叫做MY_DATA的段中。用bss_seg编译指示分配的数据不包含任何关于其位置的信息。第二个参数section-class是用于兼容2.0版本以前的Visual C++的,现在将忽略它。4 check_stack #pragma check_stack([ {on | off}] )#pragma check_stack{+ | –}如果指定off(或者“-”)指示编译程序关闭堆栈探测,或者指定on(或“+”)打开堆栈探测。如果没有给出参数,堆栈探测将根据默认设置决定。该编译指示将在出现该指示之后的第一个函数开始生效。堆栈探测既不是宏和能够生成嵌入代码函数的一部分。如果你没有给出check-_stack编译指示的参数,堆栈检查将恢复到在命令行指定的行为。详细情况见编译程序参考。#pragma check_stack和/Gs选项的互相作用情况在表2.1中说明。表 2.1 使用check_stack编译指示编译指示 用/Gs选项编译? 行为 #pragma check_stack()或#pragma check_stack 是 后续的函数关闭堆栈检查 #pragma check_stack()或#pragma check_stack 否 后续的函数打开堆栈检查 #pragma check_stack(on)或#pragma check_stack(+) 是或者否 后续的函数打开堆栈检查 #pragma check_stack(off)或#pragma check_stack(-) 是或者否 后续的函数关闭堆栈检查 5 code_seg #pragma code_seg( ["section-name"[,"section-class"] ] )指定分配函数的代码段。code_seg编译指示为函数指定默认的段。你也能够像段名一样指定一个可选的类名。使用没有段名字符串的#pragma code_seg将恢复分配到编译开始时候的状态。6 const_seg #pragma const_seg( ["section-name"[, "section-class"] ] )指定用于常量数据的默认段。data_seg编译指示除了可以工作于所有数据以外具有一样的效果。你能够使用该编译指示将你的常量数据保存在一个只读的段中。#pragma const_seg( "MY_DATA" )导致在#pragma语句后面的常量数据分配在一个叫做MY_DATA的段中。用const_seg编译指示分配的数据不包含任何关于其位置的信息。第二个参数section-class是用于兼容2.0版本以前的Visual C++的,现在将忽略它。 被 管理人员 屏蔽帖子

使用特权

评论回复
44
zhuomuniao110|  楼主 | 2016-4-30 20:15 | 只看该作者
预处理(pre-treatment),是指在进行最后加工完善以前进行的准备过程,具体应用在不同的行业或领域,会有不同的解释。在一些程序设计语言中,预处理是preprocessing的翻译。

使用特权

评论回复
45
chenyongand| | 2016-5-1 01:15 | 只看该作者
写 的很好,顶

使用特权

评论回复
46
zhuomuniao110|  楼主 | 2016-5-8 20:01 | 只看该作者
这个帖子太好了,对我非常有用,复制下来整理一下,打印了学习。

使用特权

评论回复
47
zhuotuzi| | 2016-5-8 23:08 | 只看该作者
反斜杠作为接续符时,在本行其后面不能再有任何字符,空格都不行。

使用特权

评论回复
48
zhuomuniao110|  楼主 | 2016-5-11 21:39 | 只看该作者
Windows在一个Win32程序的地址空间周围筑了一道墙。通常,一个程序的地址空间中的数据是私有的,对别的程序而言是不可见的。

使用特权

评论回复
49
玛尼玛尼哄| | 2019-4-16 00:32 | 只看该作者
这个贴其实非常好,希望大家多看看

使用特权

评论回复
50
mintspring| | 2019-4-16 00:40 | 只看该作者
常用的关键字+#就行了。

使用特权

评论回复
51
jiekou001| | 2019-4-16 16:11 | 只看该作者
此贴甚好。

使用特权

评论回复
52
operating| | 2019-4-16 16:12 | 只看该作者
满满的干货!原来预处理里面这么大学问

使用特权

评论回复
53
jiekou001| | 2019-4-16 16:12 | 只看该作者
此贴甚好。

使用特权

评论回复
54
稳稳の幸福| | 2019-4-16 23:32 | 只看该作者
也就用个宏定义

使用特权

评论回复
55
xinxianshi| | 2019-4-17 13:25 | 只看该作者
大家都会用宏

使用特权

评论回复
56
zhuomuniao110|  楼主 | 2019-4-28 09:14 | 只看该作者
一种处理方式

使用特权

评论回复
57
BigLeo8| | 2019-4-28 10:06 | 只看该作者
哇,干货呀!

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则