[转]This function or variable may be unsafe 解决办法

 [Error]'fopen' This function or variable may be unsafe


      微软的警告,主要是那些都是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" (注:加入中括号中完整的内容)

 

 

 

原文地址:http://lxn0821.blog.163.com/blog/static/2788662120114281381560/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值