关于#pragma warning 用法的研究

在阅读项目代码时,对于 #pragma warning(disable : 4251) 这个语句不是很理解,如今有时间查阅了一些资料整理以下,以备之后查找使用,也给对此有疑问提的朋友一个参考;若是有不当之处,欢迎指正;
该指令容许有选择性的修改编译器的警告消息的行为
指令格式以下:
#pragma warning( warning-specifier : warning-number-list [; warning-specifier : warning-number-list...]
#pragma warning( push[ ,n ] )
#pragma warning( pop )

主要用到的警告表示有以下几个:编程

once:只显示一次(警告/错误等)消息
default:重置编译器的警告行为到默认状态
1,2,3,4:四个警告级别
disable:禁止指定的警告信息
error:将指定的警告信息做为错误报告spa

若是你们对上面的解释不是很理解,能够参考一下下面的例子及说明
 
#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 )ci

在这段代码的最后,从新保存全部的警告信息(包括4705,4706和4707)编译器

在使用标准C++进行编程的时候常常会获得不少的警告信息,而这些警告信息都是没必要要的提示,
因此咱们可使用#pragma warning(disable:4786)来禁止该类型的警告编译

在vc中使用ADO的时候也会获得没必要要的警告信息,这个时候咱们能够经过
#pragma warning(disable:4146)来消除该类型的警告信息error


相关文章
相关标签/搜索