选择使用memcpy_s,strcpy_s还是选择strcpy,memcpy?

选择使用memcpy_s,strcpy_s还是选择strcpy,memcpy?

编者:李国帅

qq:9611153 微信lgs9611153

时间:2012-11-2

背景原因:

回答这个问题,就是在回答:选择当前不出异常,把危险隐藏起来以后发作;还是马上得到异常?

 

碰到程序若明挂起,才会发现内存溢出异常危险。而且程序越大,这些细节就越可能出现问题,隐藏的问题就越容易暴露。

 

区别:

memcpy_s,strcpy_s函数明确的指定了目标内存的大小,能够清晰的暴露出内存溢出的问题,而普通的strcpy,memcpy则不会。

为了保证内存拷贝有足够的空间,防止笔误,尽量使用memcpy_s代替memcpy。

所需资源:

       vc

例子:

下例对几个相关函数进行测试

附加

查看memcpy和memcpy_s的定义,如下:

 

         memcpy(_Dst, _Src, _SrcSize);

_CRT_INSECURE_DEPRECATE_MEMORY(memcpy_s) void__cdecl memcpy(_Out_opt_bytecapcount_(_Size) void * _Dst, _In_opt_bytecount_(_Size) const void * _Src, _In_ size_t _Size);

         memcpy_s(_Dst, _Size * sizeof(_DstType), _Src, _SrcSize);

_CRTIMP errno_t  __cdecl memcpy_s(_Out_opt_bytecap_post_bytecount_(_DstSize, _MaxCount) void * _Dst, _In_ rsize_t _DstSize, _In_opt_bytecount_(_MaxCount) const void * _Src, _In_ rsize_t _MaxCount);

总结:

异常问题最严重,也最麻烦,写程序要安全第一,不要图省事,盲目自信。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

微澜-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值