您的位置:首页 > 运维架构

warning C4996: 'fopen'

2013-08-14 14:10 134 查看
解释:微软的警告,主要是那些都是C库的函数,很多函数内部是不进行参数检测的(包括越界类的),微软担心使用这些会造成内存异常,所以就改写了一下同样功能的函数,只不过进行了参数的检测,使用这些新的就可以了。不用特意记,每个函数在给出警告时都会告诉你相应的安全函数,注意一下警告信息就可以了,使用时再
查看一下MSDN。库函数改写例子:

    mkdir改写为 _mkdir

     fopen”改写为 fopen_s

     stricmp改写为 stricmp_s

    解决:1> 根据下面的warning提示:参见“fopen”的声明

        消息:“This function or variable may be unsafe. Consider using fopen_s instead. To
disable deprecation, use _CRT_SECURE_NO_DEPRECATE. See online help for details.”

        所以可以将函数按warning提示的第二句使用fopen_s函数即可:

        eg:FILE *pFile=fopen("1.txt", "w");

           改为:

           FILE* pFile;

           fopen_s(&pFile, "1.txt", "w");

       2> 还是根据warning提示的地三句话:use _CRT_SECURE_NO_DEPRECATE

          项目|属性|配置属性|C/C++|命令行|附加选项,加入【/D "_CRT_SECURE_NO_DEPRECATE"
】(注:加入中括号中完整的内容)
       3> 降低警告级别:项目|属性|配置属性|C/C++|常规,自己根据情况降低警告级别(此法不推荐)

    注:高度重视警告:使用编译器的最高警告级别。应该要求构建是干净利落的(没有警告)。理解所有警告。通过 修改代码而不是降低警告级别来排除警告。

    编译器是你的朋友。如果它对某个构造发出警告,这经常是说明你的代码中存在潜在的问题。成功的构建应该是无声无息的(没有警告的)。【《C++编程规 范》】
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐