c++/#if _MSC_VER > 1000 #pragma once #endif 作用

本文深入解读了预编译控制在C编译器中的应用,特别是微软特有的_MSC_VER机制,以及如何通过#ifndef和#pragmaonce防止头文件被重复包含,详细比较了两种方法的优缺点。

一、#if _MSC_VER > 1000

#pragma once

#endif

解释:

这是微软的预编译控制。 
在_MSC_VER较小时,它对一些东西的支持与新版不同
 
_MSC_VER分解如下: 
MS:Microsoft(微软)的简写 
C:MSC就是Microsoft出的C编译器。 
VER:Version(版本)的简写。
 
全部加在一起就是:Microsoft的C编译器的版本

#pragma once

指示这个文件在编译时只被编译器包括一次!一般用到 .h中防止文件被重复包括!  
#if _MSC_VER > 1000

是指如果vc编译器的版本大于1000则这个语句被编译!大概小于1000的版本不支持#pragma once这个语句

很多头文件中有

#if _MSC_VER > 1000 
#pragma once
#endif // _MSC_VER > 1000

_MSC_VER 定义编译器的版本,VC++6.0就是1200

二、为了避免同一个文件被include多次 
1  #ifndef方式 
2  #pragma once方式 
在能够支持这两种方式的编译器上,二者并没有太大的区别,但是两者仍然还是有一些细微的区别。 
方式一:

#ifndef __SOMEFILE_H__
#define __SOMEFILE_H__ 
... ... // 一些声明语句 
#endif

方式二:

#pragma once    
... ... // 一些声明语句

#ifndef的方式依赖于宏名字不能冲突,这不光可以保证同一个文件不会被包含多次,也能保证内容完全相同的两个文件不会被不小心同时包含。当然,缺点就是如果不同头文件的宏名不小心“撞车”,可能就会导致头文件明明存在,编译器却硬说找不到声明的状况 
#pragma once则由编译器提供保证:同一个文件不会被包含多次。注意这里所说的“同一个文件”是指物理上的一个文件,而不是指内容相同的两个文件。带来的好处是,你不必再费劲想个宏名了,当然也就不会出现宏名碰撞引发的奇怪问题。对应的缺点就是如果某个头文件有多份拷贝,本方法不能保证他们不被重复包含。当然,相比宏名碰撞引发的“找不到声明”的问题,重复包含更容易被发现并修正。 
方式一由语言支持所以移植性好,方式二 可以避免名字冲突

解释以下CANOE的DLL扩展函数的C++头文件KeyGenAlgoExOpt.h。 //**************************************************************************************** // File name: KeyGenAlgoExOpt.h // Description: Abstract base class defines the interface for the key generation algorithm // Date: 2009-05-29 // Copyright: Vector Informatik GmbH - 2003 //**************************************************************************************** #ifndef KEY_GEN_ALGO_INTERFACE_H #define KEY_GEN_ALGO_INTERFACE_H #if _MSC_VER > 1000 #pragma once #endif #ifdef GENERATEKEYEXOPTIMPL_EXPORTS #define KEYGENALGO_API extern "C" __declspec(dllexport) #else #define KEYGENALGO_API __declspec(dllimport) #endif enum VKeyGenResultExOpt { KGREO_Ok = 0, KGREO_BufferToSmall = 1, KGREO_SecurityLevelInvalid = 2, KGREO_VariantInvalid = 3, KGREO_UnspecifiedError = 4 }; // The client has to provide a keyArray buffer and has to transfer this buffer - // including its size - to the GenerateKey method. The method checks, if the size is // sufficient. The client can discover the required size by examining the service used // transfer the key to the ECU. // Returns false if the key could not be generated: // -> keyArraySize to small // -> generation for specified security level not possible // -> variant unknown KEYGENALGO_API VKeyGenResultExOpt GenerateKeyExOpt( const unsigned char* ipSeedArray, unsigned int iSeedArraySize, const unsigned int iSecurityLevel, const char* ipVariant, const char* ipOptions, unsigned char* iopKeyArray, unsigned int iMaxKeyArraySize, unsigned int& oActualKeyArraySize); #endif // KEY_GEN_ALGO_INTERFACE_H
06-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值