what is #pragma in c

详解#Pragma预处理指令
#Pragma预处理指令可用于设定编译器状态或指示特定动作。本文介绍多种实用参数,如message参数用于输出编译信息,code_seg参数指定代码段位置,pragma once确保头文件仅被包含一次等。

#pragma 预处理指令详解[转载]

在所有的预处理指令中,#Pragma 指令可能是最复杂的了,它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作。#pragma指令对每个编译器给出了一个方法,在保持与C和C ++语言完全兼容的情况下,给出主机或操作系统专有的特征。依据定义,编译指示是机器或操作系统专有的,且对于每个编译器都是不同的。
其格式一般为: #Pragma Para
其中Para 为参数,下面来看一些常用的参数。


(1)message 参数。 Message 参数是我最喜欢的一个参数,它能够在编译信息输出窗
口中输出相应的信息,这对于源代码信息的控制是非常重要的。其使用方法为:
#Pragma message(“消息文本”)
当编译器遇到这条指令时就在编译输出窗口中将消息文本打印出来。
当我们在程序中定义了许多宏来控制源代码版本的时候,我们自己有可能都会忘记有没有正确的设置这些宏,此时我们可以用这条指令在编译的时候就进行检查。假设我们希望判断自己有没有在源代码的什么地方定义了_X86这个宏可以用下面的方法
#ifdef _X86
#Pragma message(“_X86 macro activated!”)
#endif
当我们定义了_X86这个宏以后,应用程序在编译时就会在编译输出窗口里显示“_
X86 macro activated!”。我们就不会因为不记得自己定义的一些特定的宏而抓耳挠腮了


(2)另一个使用得比较多的pragma参数是code_seg。格式如:
#pragma code_seg( ["section-name"[,"section-class"] ] )
它能够设置程序中函数代码存放的代码段,当我们开发驱动程序的时候就会使用到它。

(3)#pragma once (比较常用)
只要在头文件的最开始加入这条指令就能够保证头文件被编译一次,这条指令实际上在VC6中就已经有了,但是考虑到兼容性并没有太多的使用它。

(4)#pragma hdrstop表示预编译头文件到此为止,后面的头文件不进行预编译。BCB可以预编译头文件以加快链接的速度,但如果所有头文件都进行预编译又可能占太多磁盘空间,所以使用这个选项排除一些头文件。
有时单元之间有依赖关系,比如单元A依赖单元B,所以单元B要先于单元A编译。你可以用#pragma startup指定编译优先级,如果使用了#pragma package(smart_init) ,BCB就会根据优先级的大小先后编译。

(5)#pragma resource "*.dfm"表示把*.dfm文件中的资源加入工程。*.dfm中包括窗体
外观的定义。

(6)#pragma warning( disable : 4507 34; once : 4385; error : 164 )
等价于:
#pragma warning(disable:4507 34) // 不显示4507和34号警告信息
#pragma warning(once:4385) // 4385号警告信息仅报告一次
#pragma warning(error:164) // 把164号警告信息作为一个错误。
同时这个pragma warning 也支持如下格式:
#pragma warning( push [ ,n ] )
#pragma warning( pop )
这里n代表一个警告等级(1---4)。
#pragma warning( push )保存所有警告信息的现有的警告状态。
#pragma warning( push, n)保存所有警告信息的现有的警告状态,并且把全局警告
等级设定为n。
#pragma warning( pop )向栈中弹出最后一个警告信息,在入栈和出栈之间所作的
一切改动取消。例如:
#pragma warning( push )
#pragma warning( disable : 4705 )
#pragma warning( disable : 4706 )
#pragma warning( disable : 4707 )
//.......
#pragma warning( pop )
在这段代码的最后,重新保存所有的警告信息(包括4705,4706和4707)。
(7)pragma comment(...)
该指令将一个注释记录放入一个对象文件或可执行文件中。
常用的lib关键字,可以帮我们连入一个库文件。
(8)用pragma导出dll中的函数

    传统的到出 DLL 函数的方法是使用模块定义文件 (.def),Visual C++ 提供了更简洁方便的方法,那就是“__declspec()”关键字后面跟“dllexport”,告诉连接去要导出这个函数,例如:

__declspec(dllexport) int __stdcall MyExportFunction(int iTest);

    把“__declspec(dllexport)”放在函数声明的最前面,连接生成的 DLL 就会导出函数“_MyExportFunction@4”。

    上面的导出函数的名称也许不是我的希望的,我们希望导出的是原版的“MyExportFunction”。还好,VC 提供了一个预处理指示符“#pragma”来指定连接选项 (不仅仅是这一个功能,还有很多指示功能) ,如下:

#pragma comment(linker,"/EXPORT:MyExportFunction=_MyExportFunction@4")

    这下就天如人愿了:)。如果你想指定导出的顺序,或者只将函数导出为序号,没有 Entryname,这个预处理指示符 (确切地说是连接器) 都能够实现,看看 MSDN 的语法说明:

/EXPORT:entryname[,@ordinal[,NONAME]][,DATA]

   @ordinal 指定顺序;NONAME 指定只将函数导出为序号;DATA 关键字指定导出项为数据项。



每个编译程序可以用#pragma指令激活或终止该编译程序支持的一些编译功能。例如,对循环优化功能:
#pragma loop_opt(on) // 激活
#pragma loop_opt(off) // 终止
有时,程序中会有些函数会使编译器发出你熟知而想忽略的警告,如“Parameter xxx is never used in function xxx”,可以这样:
#pragma warn —100 // Turn off the warning message for warning #100
int insert_record(REC *r)
{ /* function body */ }
#pragma warn +100 // Turn the warning message for warning #100 back on
函数会产生一条有唯一特征码100的警告信息,如此可暂时终止该警告。
每个编译器对#pragma的实现不同,在一个编译器中有效在别的编译器中几乎无效。可从编译器的文档中查看。

严重性 代码 说明 项目 文件 行 禁止显示状态 错误(活动) E0020 未定义标识符 "selectedCurves" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 257 错误(活动) E0153 表达式必须具有类类型,但它具有类型 "NXOpen::Update *" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 304 错误(活动) E0020 未定义标识符 "filletRadius" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 259 错误(活动) E0140 函数调用中的参数太多 caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 427 错误(活动) E0415 不存在从 "void" 转换到 "NXOpen::Point3d" 的适当构造函数 caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 427 错误(活动) E0135 class "NXOpen::Point3d" 没有成员 "DistanceTo" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 380 错误(活动) E0135 class "NXOpen::Point3d" 没有成员 "DistanceTo" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 384 错误(活动) E0135 class "NXOpen::Point3d" 没有成员 "DistanceTo" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 388 错误(活动) E0135 class "NXOpen::Point3d" 没有成员 "DistanceTo" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 392 错误(活动) E0135 class "NXOpen::Curve" 没有成员 "ParametrizePoint" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 416 错误(活动) E0135 class "NXOpen::Curve" 没有成员 "GetLimits" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 412 错误(活动) E0135 class "NXOpen::Curve" 没有成员 "GetEndPoints" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 375 错误(活动) E0135 class "NXOpen::Curve" 没有成员 "GetEndPoints" caotudaoR D:\NXopen\BaiduSyncdisk\studio\caotudaoR\caotudaoR.cpp 376 “#ifndef NXOpen_CURVE_HXX_INCLUDED #define NXOpen_CURVE_HXX_INCLUDED //-------------------------------------------------------------------------- // Header for C++ interface to JA API //-------------------------------------------------------------------------- // // Source File: // Curve.ja // // Generated by: // apiwrap // // WARNING: // This file is automatically generated - do not edit by hand // #ifdef _MSC_VER #pragma once #endif #include <NXOpen/NXDeprecation.hxx> #include <vector> #include <NXOpen/NXString.hxx> #include <NXOpen/Callback.hxx> #include <NXOpen/Drawings_DraftingCurveInfo.hxx> #include <NXOpen/IBaseCurve.hxx> #include <NXOpen/ICurve.hxx> #include <NXOpen/INXObject.hxx> #include <NXOpen/IProfile.hxx> #include <NXOpen/SmartObject.hxx> #include <NXOpen/libnxopencpp_exports.hxx> #ifdef _MSC_VER #pragma warning(push) #pragma warning(disable:4996) #endif #ifdef __GNUC__ #pragma GCC diagnostic ignored "-Wdeprecated-declarations" #endif namespace NXOpen { class Curve; namespace Assemblies { class Component; } class BasePart; namespace Drawings { class DraftingCurveInfo; } class IBaseCurve; class ICurve; class INXObject; class IProfile; class SmartObject; class _CurveBuilder; class CurveImpl; /** Represents a curve. <br> This is an abstract class, and cannot be instantiated <br> <br> Created in NX3.0.0. <br> */ class NXOPENCPPEXPORT Curve : public NXOpen::SmartObject, public virtual NXOpen::ICurve, public virtual NXOpen::IProfile { private: CurveImpl * m_curve_impl; private: friend class _CurveBuilder; protected: Curve(); public: ~Curve(); /** Creates new DraftingCurveInfo object @return New DraftingCurveInfo object. Returns NULL if the input curve is not a drafting curve <br> Created in NX10.0.0. <br> <br> License requirements : None */ public: virtual NXOpen::Drawings::DraftingCurveInfo * GetDraftingCurveInfo ( ); /** Returns the length of the object @return <br> Created in NX3.0.0. <br> <br> License requirements : None */ public: virtual double GetLength ( ); /**Returns the reference state of a curve <br> Created in NX8.0.0. <br> <br> License requirements : None */ public: virtual bool IsReference ( ); }; } #ifdef _MSC_VER #pragma warning(pop) #endif #ifdef __GNUC__ #ifndef NX_NO_GCC_DEPRECATION_WARNINGS #pragma GCC diagnostic warning "-Wdeprecated-declarations" #endif #endif #undef EXPORTLIBRARY #endif ”“#ifndef NXOpen_UGMATH_HXX_INCLUDED #define NXOpen_UGMATH_HXX_INCLUDED //-------------------------------------------------------------------------- // Header for C++ interface to JA API //-------------------------------------------------------------------------- // // Source File: // ugmath.ja // // Generated by: // apiwrap // // WARNING: // This file is automatically generated - do not edit by hand // #ifdef _MSC_VER #pragma once #endif #include <NXOpen/NXDeprecation.hxx> #include <vector> #include <NXOpen/NXString.hxx> #include <NXOpen/Callback.hxx> #ifdef _MSC_VER #pragma warning(push) #pragma warning(disable:4996) #endif #ifdef __GNUC__ #pragma GCC diagnostic ignored "-Wdeprecated-declarations" #endif namespace NXOpen { /** Represents three-dimensional cartesian coordinates for a point <br> Created in NX3.0.0. <br> */ struct Point3d { public: /** x */ double X; public: /** y */ double Y; public: /** z */ double Z; public: Point3d() : X(), Y(), Z() { } /** Constructor for the Point3d struct. */ public: Point3d(double xInitial /** x */ , double yInitial /** y */ , double zInitial /** z */ ) : X(xInitial), Y(yInitial), Z(zInitial) { } }; /** Represents a three-dimensional vector <br> Created in NX3.0.0. <br> */ struct Vector3d { public: /** x */ double X; public: /** y */ double Y; public: /** z */ double Z; public: Vector3d() : X(), Y(), Z() { } /** Constructor for the Vector3d struct. */ public: Vector3d(double xInitial /** x */ , double yInitial /** y */ , double zInitial /** z */ ) : X(xInitial), Y(yInitial), Z(zInitial) { } }; /** Represents a 3 x 3 matrix <br> Created in NX3.0.0. <br> */ struct Matrix3x3 { public: /** xx */ double Xx; public: /** xy */ double Xy; public: /** xz */ double Xz; public: /** yx */ double Yx; public: /** yy */ double Yy; public: /** yz */ double Yz; public: /** zx */ double Zx; public: /** zy */ double Zy; public: /** zz */ double Zz; public: Matrix3x3() : Xx(), Xy(), Xz(), Yx(), Yy(), Yz(), Zx(), Zy(), Zz() { } /** Constructor for the Matrix3x3 struct. */ public: Matrix3x3(double xxInitial /** xx */ , double xyInitial /** xy */ , double xzInitial /** xz */ , double yxInitial /** yx */ , double yyInitial /** yy */ , double yzInitial /** yz */ , double zxInitial /** zx */ , double zyInitial /** zy */ , double zzInitial /** zz */ ) : Xx(xxInitial), Xy(xyInitial), Xz(xzInitial), Yx(yxInitial), Yy(yyInitial), Yz(yzInitial), Zx(zxInitial), Zy(zyInitial), Zz(zzInitial) { } }; /** Represents two-dimensional cartesian coordinates for a point <br> Created in NX6.0.0. <br> */ struct Point2d { public: /** x */ double X; public: /** y */ double Y; public: Point2d() : X(), Y() { } /** Constructor for the Point2d struct. */ public: Point2d(double xInitial /** x */ , double yInitial /** y */ ) : X(xInitial), Y(yInitial) { } }; /** Represents four-dimensional homogeneous coordinates for a point. To convert to three-dimensional cartesian coordinates, divide x, y and z by w. <br> Created in NX8.5.0. <br> */ struct Point4d { public: /** x */ double X; public: /** y */ double Y; public: /** z */ double Z; public: /** weight */double W; public: Point4d() : X(), Y(), Z(), W() { } /** Constructor for the Point4d struct. */ public: Point4d(double xInitial /** x */ , double yInitial /** y */ , double zInitial /** z */ , double wInitial /** weight */) : X(xInitial), Y(yInitial), Z(zInitial), W(wInitial) { } }; } #ifdef _MSC_VER #pragma warning(pop) #endif #ifdef __GNUC__ #ifndef NX_NO_GCC_DEPRECATION_WARNINGS #pragma GCC diagnostic warning "-Wdeprecated-declarations" #endif #endif #endif ”
09-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值