博客
关于我
vs2013提示需要加_s才能编译的解决办法
阅读量:603 次
发布时间:2019-03-12

本文共 701 字,大约阅读时间需要 2 分钟。

编译报错提示使用fopen时不安全,需改为fopen_s或添加预处理器定义《CRT_SECURE_NO_WARNINGS》。

错误提示:

error C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.

解决办法:选用更适合的方法

  • 直接修改函数名为fopen_s

    将所有fopen函数修改为fopen_s,适合熟悉C语言结构的开发者,但需要重新检查所有使用情况,可能增加维护工作。

  • 使用预处理器宏《CRT_SECURE_NO_WARNINGS》

    更优的选择,通过调整项目配置抑制警告,避免代码改动,尤其适合保持现有代码结构的需求。

  • 操作步骤:

  • 打开项目属性

    右键项目,选择 properties。

  • 进入C/C++选项

    在属性窗口,选择展开菜单,找到 VC++ 定义,接着进入 预处理器 定义。

  • 添加预处理器宏

    在宏定义处添加 CRT_SECURE_NO_WARNINGS,避免错误,该字符串后不需要逗号或前缀。

  • 验证方法:

    保存更改,重新编译项目。若错误消失,说明配置成功,可以正常使用fopen而无警告。

    注意事项:

    确保该宏仅用于需要的项目,避免遗漏或影响其他项目。若有多个配置(如Debug和Release),检查各配置是否都添加了宏。

    使用方法2更合理且维护友好,推荐选用。希望这能帮你顺利解决问题。

    转载地址:http://lplxz.baihongyu.com/

    你可能感兴趣的文章
    OAuth 2.0 MAC Tokens
    查看>>
    OAuth 及 移动端鉴权调研
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>