Visual Studio编辑器中C4996 ‘scanf‘: This function or variable may be unsafe.问题解决方案

目录

​编辑

题目:简单的a+b

1.  题目描述

2.  输入格式

3.  输出格式

4.  样例输入

5.  样例输出

6.  解题思路

7.  代码示例

8.  报错解决

方案一

方案二

方案三

方案四

总结


题目:简单的a+b

1.  题目描述

输入两个整数a和b,计算a+b的和

本题很简单,但是注意此题是多组测试数据,即需要不停的接收系统的测试输入,你都可以计算结果并输出

2.  输入格式

输入两个整数A和B

范围不超过2^10

3.  输出格式

求A+B

4.  样例输入

1 1
10 20

5.  样例输出

2
30

6.  解题思路

首先,本题的首要条件是“需要不停的接收系统的测试输入,你都可以计算结果并输出”

我们可以通过while循环,不断地输入数据,进行条件判断执行

注:while(表达式){若干语句}//循环语句及其格式,若表达式里的语句成立,执行若干语句

而如何进行输入,就需要用到scanf语句

注:scanf("输入模式",地址列表);//输入语句及其格式。注:地址列表一定要加取地址符号&,如:&a,&b

而输入完对于输入语句的计算以及输出,我们可以直接在printf里执行

注:printf("输出模式",输出列表);//输出语句及其格式。注:输出模式和输出列表一一对应,如:printf("%d%d",a,b);

7.  代码示例

#include<stdio.h>
int main()
{
    int a=0,b=0;
    while(~scanf("%d%d", &a, &b))   
    {
        printf("%d\n",a+b);
    }    
    return 0;
}

想要退出循环,按下Ctrl+Z,回车才会退出循环,可能需要多循环几次

其中需要注意的一点是,在Visual Studio编辑器中可能会出现报错

'scanf': This function or variable may be unsafe. Consider using scanf_s instead. To disable deprecation, use _CRT_SECURE_NO_WARNINGS. See online help for details.	Project16	D:\Visual Studio\project\Project16\Project16\FileName.cpp	5	

8.  报错解决

这里我们有两种解决方案:

方案一

将scanf改为scanf_s

#include<stdio.h>
int main()
{
    int a = 0, b = 0;
    while (~scanf_s("%d%d", &a, &b))   
    {
        printf("%d\n", a + b);
    }
    return 0;
}

        将 scanf 函数改为 scanf_s 函数的作用是增加输入的安全性,防止发生缓冲区溢出的问题。scanf_s 是 Microsoft 提供的安全版本的输入函数,相比于 scanf,它会在读取数据时进行一些额外的检查,并限制输入的字符数量。

        使用 scanf 函数时,如果输入的数据长度超过了目标变量所能容纳的大小,就可能导致缓冲区溢出,造成安全隐患。而 scanf_s 函数在读取数据时,可以指定目标变量所能接收的最大字符数量,从而避免缓冲区溢出的情况。

scanf_s 的函数签名如下:

int scanf_s(const char *format, ...);

        与 scanf 不同的是,scanf_s 在读取字符串时需要指定字符串的最大长度,以确保输入不会超出缓冲区的大小。比如,使用 scanf_s 读取一个字符串时,可以这样写:

char str[20];
scanf_s("%19s", str, sizeof(str));

        在上述代码中,限定了输入的字符串长度最多为 19 个字符(因为数组大小是 20,还要留一个字符给字符串结尾的空字符)。这样做可以防止用户输入超过目标变量所能容纳的字符数量。

        总之,通过使用 scanf_s 函数,我们可以增加输入操作的安全性,防止发生缓冲区溢出的问题。然而,需要注意的是,scanf_s 是 Microsoft 特定的函数,在其他编译器中可能不被支持。因此,在使用 scanf_s 时应该注意兼容性问题。

方案二

在代码最上方加:

#define _CRT_SECURE_NO_WARNINGS
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>


int main()
{
    int a = 0, b = 0;
    while (~scanf("%d%d", &a, &b))   
    {
        printf("%d\n", a + b);
    }
    return 0;
}

        记住一定是在代码的最上方加,否则依旧报错,因为预处理指令是在编译器开始编译之前执行的。而编译器是按照源代码的顺序逐行读取和编译代码的,因此如果 #define _CRT_SECURE_NO_WARNINGS 放在其他代码之后,那么编译器可能会在处理到某些不安全的函数时已经发出了警告信息,从而无法起到禁用警告的效果。

   #define _CRT_SECURE_NO_WARNINGS 是一条预处理指令(preprocessor directive),在 C 语言编程中常用于禁用特定编译器警告信息。

        在 Microsoft Visual Studio 编译器中,使用一些被认为不安全的函数(如 fopenscanf 等)时,编译器会发出警告。这些警告是为了提醒开发者使用更安全的函数或者采取更安全的方法,以避免潜在的安全问题(如缓冲区溢出)。

        然而,在某些情况下,我们可能需要继续使用这些被标记为不安全的函数,例如在旧代码的迁移过程中或者与其他平台进行兼容性开发时。此时,#define _CRT_SECURE_NO_WARNINGS 可以用来禁用这些特定警告,使得编译器不再产生相关的警告信息。

        通过包含该预处理指令,我们告诉编译器不要发出与安全问题相关的警告,这样在编译时就不会看到相关的警告信息了。但需要注意的是,禁用这些警告并不会改变函数的行为,因此在使用这些函数时仍然需要谨慎确保输入的安全性。

        需要强调的是,禁用编译器警告可能会导致潜在的安全问题被忽略,因此在使用 #define _CRT_SECURE_NO_WARNINGS 时需要权衡利弊,并尽可能采取更安全的函数或方法来处理相应的问题。

方案三

在代码最上方加:

#define _CRT_SECURE_NO_DEPRECATE
#define _CRT_SECURE_NO_DEPRECATE
#include<stdio.h>


int main()
{
    int a = 0, b = 0;
    while (~scanf("%d%d", &a, &b))   
    {
        printf("%d\n", a + b);
    }
    return 0;
}

        放到最上方的原因同方案二

  #define _CRT_SECURE_NO_DEPRECATE 是一条预处理指令(preprocessor directive),在 C 语言编程中常用于禁用某些特定函数的警告信息,具体来说,它可以用来避免使用已经被VS 标记为不安全的函数时产生的编译器警告。

        例如,在使用 fopen 函数时,如果不使用 _CRT_SECURE_NO_DEPRECATE,则可能会出现类似以下的编译器提示:

warning C4996: 'fopen': This function or variable may be unsafe. Consider using fopen_s instead.

        这是因为在Visual Studio中,许多标准 C 库函数被认为是不安全的,因为它们可能会受到缓冲区溢出等安全问题的影响。因此,为了更好地保护程序的安全性,Microsoft 建议使用相应的安全函数替代这些不安全的函数。

        然而,对于一些旧的代码或者遗留系统,可能难以修改所有不安全函数的调用。在这种情况下,我们可以使用 _CRT_SECURE_NO_DEPRECATE 来禁用编译器警告,从而继续使用这些不安全的函数。

        需要注意的是,使用 _CRT_SECURE_NO_DEPRECATE 可能会降低程序的安全性,因此在使用时要谨慎权衡利弊,并尽可能使用更安全的函数或方法来处理相应的问题。

方案四

在代码上方加:

#pragma warning(disable:4996)
#pragma warning(disable:4996)
#include<stdio.h>


int main()
{
    int a = 0, b = 0;
    while (~scanf("%d%d", &a, &b))   
    {
        printf("%d\n", a + b);
    }
    return 0;
}

   #pragma warning(disable:4996) 是一条预处理指令(preprocessor directive),用来禁用编译器产生与函数安全问题相关的警告信息。这个警告通常出现在使用一些被标记为不安全的函数时,例如 scanfstrcpy 等。警告的代码是 C4996

        在 Visual Studio 中,这些函数通常被标记为不安全,因为它们可能导致缓冲区溢出等安全问题。因此,编译器会发出警告信息,提醒开发者使用更安全的函数或方法。

        但是,在某些情况下,我们需要继续使用这些被标记为不安全的函数,例如在旧代码的迁移过程中或者与其他平台进行兼容性开发时。此时,#pragma warning(disable:4996) 可以用来禁用这个特定的警告,使得编译器不再产生相关的警告信息。

        通过包含该预处理指令,我们告诉编译器不要发出与安全问题相关的警告,这样在编译时就不会看到相关的警告信息了。但需要注意的是,禁用这些警告并不会改变函数的行为,因此在使用这些函数时仍然需要谨慎确保输入的安全性。

        需要注意的是,#pragma warning(disable:4996) 只是针对 Visual Studio 编译器有效,如果使用其他编译器,可能需要使用不同的预处理指令或者参数。

        总之,#pragma warning(disable:4996) 用于禁用与函数安全问题相关的警告,可以帮助我们在某些情况下继续使用被标记为不安全的函数。但是,禁用编译器警告可能会导致潜在的安全问题被忽略,因此在使用 #pragma warning(disable:4996) 时需要权衡利弊,并尽可能采取更安全的函数或方法来处理相应的问题。

总结

方案一:将scanf改为scanf_s

方案二:在代码最上方加:#define _CRT_SECURE_NO_WARNINGS

方案三:在代码最上方加:#define _CRT_SECURE_NO_DEPRECATE

方案四:在代码上方加:#pragma warning(disable:4996)

简单来说,编译器看不到错我,我就是对的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/248014.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

12.15

写这段代码改了好几个小时&#xff0c;从有这个想法到完成花费了比较久的时间&#xff0c;也很有成就感。速成课给的伪代码思路漏掉了需要判断最小数是否正好是这个数本身这个条件&#xff0c;所以一直报错。所以写代码要把每种可能性都涵盖&#xff0c;不然程序就会出问题。之…

DVGO 代码阅读

BBx 的大小范围是 根据 相机的 位姿来构建的&#xff0c;会刚好 Cover 相机的移动范围&#xff0c;相当于 StreetSurf 里面的 close-range 的部分&#xff0c;代码在compute_bbox_by_cam_frustrm_unbounded 这个函数里面&#xff1a; xyz_min, xyz_max _compute_bbox_by_cam_f…

springcloud项目实战之自定义负载均衡器

系列文章 。 写在前面 本部分看下如何自定义负载均衡器从而满足业务对于负载均衡特定的需求。 源码 。 1&#xff1a;负载均衡的知识点 1.1&#xff1a;什么是负载均衡&#xff1f; 多台服务器随机的选择一台处理请求的技术&#xff0c;叫做负载均衡自己总结的&#xff0c…

jstat虚拟机统计信息监控工具

jstat虚拟机统计信息监控工具 1、jstat&#xff08;JVM Statistics Monitorning Tool&#xff09; 用于监控虚拟机各种运行状态信息的命令行工具。 它可以显示本地或远程虚拟机进程中的类装载、内存、垃圾收集、JIT编译等运行数据&#xff0c;它是运行期定位虚拟机 性能问题…

VRRP协议详解

目录 一、基础概念 1、概念 2、VRRP的基本结构 状态机 二、VRRP主备备份工作过程 1、备份工作过程 2、VRRP的负载分担工作 三、实验 一、基础概念 1、概念 VRRP能够在不改变组网的情况下&#xff0c;将多台路由器虚拟成一个虚拟路由器&#xff0c;通过配置虚拟路由器的I…

StarCCM+ 导入STL几何模型进行仿真

使用 StarCCM 进行仿真时&#xff0c;通常都是用 3D-CAD Model 导入 CAD 类型的几何模型。但对于一些特殊情况&#xff0c;例如通过三维重建等方法获得的几何模型是 STL 文件而非 CAD 文件&#xff0c;这种情况下可以通过 Import Surface Mesh 的方法导入 STL 文件进行仿真&…

浮在文字上面的下划线的设置css

话不多说直接贴代码 前5行css就是实现的代码&#xff1a; p {text-decoration-line: underline;text-underline-offset: -7.5px;text-decoration-thickness: 5px;text-underline-position: under;text-decoration-color: #FFF200;color: #666;font-size: 20px;line-height: 2…

【源码系列】外卖系统外卖平台外卖软件开发外卖小程序APP

系统概念 外卖系统是一套类似美团和饿了么的外卖送餐解决方案&#xff0c;可以在PC、H5、APP、小程序、微信等全平台进行操作。系统配备用户端、商户端、配送端、管理端&#xff0c;可供消费者、商家、骑手&#xff0c;平台多角色使用。同时提供调度中心、分站管理等增值功能。…

openoffice安装

安装openoffice 下载安装包 建议去官网下载&#xff0c;这里给出官网地址&#xff1a;https://www.openoffice.org/download/ 这里以linux为例&#xff0c;所以我下载的是unbantu的版本(deb) 解压安装包 tar -zxvf Apache_OpenOffice_4.1.13_Linux_x86-64_install-deb_zh-…

【lesson15】MySQL表基本查询 (retrieve(2))

文章目录 表的基本操作介绍retrieve结果排序建表基本测试 筛选分页结果建表测试 表的基本操作介绍 CRUD : Create(创建), Retrieve(读取)&#xff0c;Update(更新)&#xff0c;Delete&#xff08;删除&#xff09; retrieve 结果排序 建表 建表这里就不建了&#xff0c;因为…

【期末复习向】n元gram的应用

当 n 1 时&#xff0c; 即出现 在 第 i 位 上 的基 元 w i 独 立于 历 史 。 一元文法也 被 写 为 uni-gram 或 monogram&#xff1b; 当 n 2 时 , 2-gram ( bi-gram ) 被称 为 1 阶 马 尔 可夫 链&#xff1b; 当 n 3 时 , 3-gram( tri-gram ) 被称为 2 阶马尔 可 夫 链 &am…

上门回收小程序开发,让环保发展成收益

如今资源回收&#xff0c;保护环境已成为全球人民共同追求的目标&#xff0c;人们的环保意识也逐渐提高&#xff0c;回收行业受到了大众的关注。 在移动互联网的发展下&#xff0c;传统回收行业也逐渐向线上智能化转型&#xff0c;线上上门回收小程序也逐渐出现在了大众生活中…

C语言的system函数简介

函数原型 包含在头文件 “stdlib.h” 中 int system(const char * command) 函数功能 执行 dos(windows系统) 或 shell(Linux/Unix系统) 命令&#xff0c;参数字符串command为命令名。另&#xff0c;在windows系统下参数字符串不区分大小写。 说明&#xff1a;在windows系统中&…

基于ssm服装定制系统源码和论文

idea 数据库mysql5.7 数据库链接工具&#xff1a;navcat,小海豚等 环境&#xff1a; jdk8 tomcat8.5 开发技术 ssm 基于ssm服装定制系统源码和论文751 1.1项目研究的背景 困扰管理层的许多问题当中,服装定制将是广大用户们不可忽视的一块。但是管理好服装定制又面临很多麻…

VINS-MONO代码解读6----pose_graph

开始pose_graph部分&#xff0c;本部分记住一句话无论是快速重定位还是正常重定位&#xff0c;求出 T w 1 w 2 T_{w_1w_2} Tw1​w2​​就是终极目标。 还剩一个整体Pipeline~~ 1. pose_graph_node.cpp 注意&#xff0c;定义全局变量时即实例化了一个对象 PoseGraph posegra…

26种主流的神经网络偏微分方程求解方法汇总

偏微分方程&#xff08;PDE&#xff09;是数学中一门重要的分支&#xff0c;应用范围广泛涉及自然科学、工程技术、生物学领域等。然而我们都知道&#xff0c;偏微分方程的求解过程异常艰难&#xff0c;如果碰上了特别复杂的&#xff0c;传统的计算方法可能需要数百万个CPU小时…

[多线程]一篇文章带你看懂Java中的synchronized关键字(线程安全)锁的深入理解

目录 1.前言 2.synchronized的特性 2.1synchronized前言 2.2乐观锁和悲观锁 2.3重量级锁和轻量级锁 重量级锁 &#xff1a; 轻量级锁&#xff1a; 2.4自旋锁和挂起等待锁 2.5 公平锁和非公平锁 公平锁&#xff1a; 非公平锁&#xff1a; 2.6可重入锁和不可重入锁 可…

bat 脚本的常用特殊符号

1、 命令行回显屏蔽符 2、% 批处理变量引导符 3、> 重定向符 4、>> 重定向符 5、<、>&、<& 重定向符 6、| 命令管道符 7、^ 转义字符 8、& 组合命令 9、&& 组合命令 10、|| 组合命令 11、"" 字符串界定符 12、, 逗号…

报错“找不到mfc100u.dll,程序无法继续执行”的解决方法,完美解决

在软件操作过程中&#xff0c;部分用户可能遇到"计算机缺失mfc140u.dll导致无法启动程序"的困扰。这种情况常常发生在启动某特定应用&#xff0c;特别是需要VC Redistributable支持的软件时。以下为详尽解决策略&#xff0c;让用户轻松应对这类技术难题&#xff0c;重…

React中的setState执行机制

我这里今天下雨了&#xff0c;温度一下从昨天的22度降到今天的6度&#xff0c;家里和学校已经下了几天雪了&#xff0c;还是想去玩一下的&#xff0c;哈哈&#xff0c;只能在图片里看到了。 一. setState是什么 它是React组件中用于更新状态的方法。它是类组件中的方法&#x…
最新文章