当前位置:网站首页>关于在vs中使用scanf不安全的问题
关于在vs中使用scanf不安全的问题
2022-04-23 14:13:00 【KissKernel】
#关于在vs中使用scanf不安全的问题
###首先是scanf为什莫不安全
首先是关于内存溢出的问题,scanf在使用的时候不会检测你输入的字符串长度所以这时就有内存溢出的风险。
#include<stdio.h>
int main()
{
char arr[6]={
0};
scanf("%s",&arr);
//假设输入helloworld就会出现越界访问的问题,所以scanf在这种情况下会不安全。
}
###其次是如何解决scanf不安全的问题
解决这个问题有两个方法
1.一个是打开vs 项目选项看到最后一个选项属性

将SDL检查禁用
2.在文件.c中第一行插入下面这段代码;
#define _CRT_SECURE_NO_WARNINGS
在每个文件的开头都插入显然略显麻烦,所以还有一个一劳永逸的方法,下面我来介绍一下。首先找到你的vs安装路径找到这个文件newc++file.c将他复制到桌面上然后在将上面一段代码复制进去,再将这个文件复制回原来的路径底下。替换原来的文件即可。*那么这里为什么要这莫做呢,因为当你在原来路径直接更改newc++file.c会提示你没有权限更改。
###最后是为什么scanf_s安全
vs中提供的scanf_s 函数需要规定输入字符的个数,所以需要额外输入一个限定数字。这样就可以保证函数不会越界访问。
#include<stdio.h>
int main()
{
char arr[6];
scanf_s("%s",&arr,5);//那么这个时候就不会造成意外的越界访问
return 0;
}
只会有人为的越界访问比如你要输入hello五个字符却只定义了arr[5]那么字符串结尾的\0;会因为无处安放而造成越界。
当然我还是建议在日常编程中使用scanf因为scanf_s是vs自己写出来的在其他的编译器上会报错,可复用性太差。
以上文件我都上传在了我的码云,需要的可以看看
链接
版权声明
本文为[KissKernel]所创,转载请带上原文链接,感谢
https://blog.csdn.net/qq_62745420/article/details/124000631
边栏推荐
猜你喜欢

Nacos作为配置中心(四) 使用Demo

Man man notes and @ reboot usage of crontab

字节面试编程题:最小的K个数

Thread group ThreadGroup uses introduction + custom thread factory class to implement threadfactory interface

TLS/SSL 协议详解 (28) TLS 1.0、TLS 1.1、TLS 1.2之间的区别

常见存储类型和FTP主被动模式解析

微信小程序将原生请求通过es6的promise来进行优化

01-nio basic ByteBuffer and filechannel

MySQL数据库讲解(八)

微信小程序客服接入,实现发送和接收消息
随机推荐
循环队列的基本操作,你学会了吗?
JS parabola motion packaging method
SSH 通过跳板机连接远程主机
MySQL同步Could not find first log file name in binary log index file错误
Qt实战:云曦聊天室篇
C语言知识点精细详解——初识C语言【1】——你不能不知的VS2022调试技巧及代码实操【1】
MySQL数据库讲解(十)
MySQL-InnoDB-事务
man man随记和crontab的@reboot用法
TUN 设备原理
TLS/SSL 协议详解 (28) TLS 1.0、TLS 1.1、TLS 1.2之间的区别
Nacos作为配置中心(四) 使用Demo
GFS分布式文件系统(理论)
openstack理论知识
Date的after时间判断
source insight via samba
ActiveMQ Basics
Use the executors class to quickly create a thread pool
JS progress bar, displaying the loading progress
Pass in external parameters to the main function in clion