关于 #pragma warning()

1. #pragma warning只对当前文件有效(对于.h,对包含它的cpp也是有效的),而不是对整个工程的所有文件有效。当该文件编译结束,设置也就失去作用。

2. #pragma warning(push) 存储当前报警设置。

#pragma warning(push, n) 存储当前报警设置,并设置报警级别为n。n为从1到4的自然数。

3. #pragma warning(pop) 恢复之前压入堆栈的报警设置。在一对push和pop之间作的任何报警相关设置都将失效。

4. #pragma warning(disable: n)将某个警报置为失效

5. #pragma warning(default: n)将报警置为默认

6. 某些警告如C4309是从上到下生效的。即文件内#pragma warning从上到下遍历,依次生效。

7. 某些警告例如C4189是以函数中最后出现的#pragma warning设置为准的,其余针对该报警的设置都是无效的。

8. 某些警告(MSDN认为是大于等于C4700的警告)是在函数结束后才能生效。

参考:#pragma warning(disable:4996) 

http://blog.csdn.net/liangzhaoyang1/article/details/51969386

 

posted @ 2017-05-14 21:27  ll7  阅读(1137)  评论(0编辑  收藏  举报