VS2012关于scanf和gets的不安全问题

本文介绍如何在C/C++中使用scanf_s和gets_s函数来读取字符串,并通过设置最大读取长度来避免内存溢出的问题。此外,还讨论了在不同编译器环境下如何正确地使用这些函数。

用scanf_s("%",&,长度)和gets_s(str,长度)就可以。

C中没有scanf_s(),只有scanf()scanf()在读取时不检查边界,所以可能会造成内在泄露。

早在vc++2005/2008中就提供了scanf_s(),在调用时,必须提供一个数字以表明最多读取多少位字符。

不过到了VS2012,提示从警告变成了错误。。

不过在各大OJ中,使用了scanf_s,用C++,G++都是不能通过编译的,但是如果编译器又想用VS2012的话,可以在程序段头加下面这段话:#pragma warning(disable:4996)  

其功能是将4996警告屏蔽。它是微软新的C库提供的带有检查的函数,有内存溢出检测。可以防止一部分程序bug, 抵制缓冲区溢出攻击(buffer overflow attack). 但是据说应该有速度上有牺牲。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值