CRT中的安全功能

9 篇文章 0 订阅

CRT

学习于微软

新版本CRT函数具有_s(“安全”)的后缀。

例如, strcpy 函数无法验证调用字符串复制它是否超过它目标缓冲区。 但其安全副本: strcpy_s,采用缓冲区的大小作为参数,因此,它可以确定缓冲区是否溢出。

带有安全功能同样不能阻止发生安全错误, 如果使用 strcpy_s 复制为一个字符为十六进制字符缓冲区,这是在部分的错误; strcpy_s 不能更正此错误,但带有安全功能会执行进一步的检查错误状态,可以检测该错误并将调用无效参数处理程序通知您。

应用举例:

#define SIZE 26
char buf[SIZE];
errno_t err;
tm gmtm;
/*
char *asctime( 
   const struct tm *timeptr 
);
*/
asctime(&gmtm);
/*
errno_t asctime_s( 
   char* buffer,
   size_t numberOfElements,
   const struct tm *_tm 
);
*/
err=asctime_s(buf,SIZE,&gmtm);

定义 _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 到 1 允许自动调用更安全的变量标准 CRT 函数的模板重载。

#define _CRT_SECURE_CPP_OVERLOAD_STANDARD_NAMES 1
...
errno_t err;
char szBuf[10];
err=strcpy_s(szBuf, "test"); // ==> strcpy_s(szBuf, 10, "test")	//在后台,对 strcpy 的调用会更改为。 strcpy_s 的调用与自动所提供的范围参数。

zhengbanxian
3.12

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值