How to debug a buffer overrun

今天在vs上调试c++代码,遇到一个bug,程序直接跳出错误“A buffer overrun has occurred ”花了一会时间改这个bug,现在把这个过程记录下来。

一般如果是栈出这种错误这种情况很可能发生在某个函数调用结束返回的时候出的问题,说明栈调用里面存在越界的情况,然后就开始检查我的代码,我发现我也没有新定义string,或者使用什么memcpy,strcpy的函数,然后求助于google,发现了msdn对于这个问题有一个不错的解释,原链接,英文的:Avoiding Buffer Overruns

下面将我自己的理解下下来以及我今天犯得错误,以避免以后再出现类似问题:
一般来说,buffer overrun 这种错误很多都是由于源代码不安全导致的,通常都是因为没有检查数据的输入,导致内存中出现不可预知的数据从而导致错误发生,一般都会存在内存拷贝操作,比如strcat,strcpy,wscpy等这些操作。下面是经常导致发生这个错误的一些原因:

1.static buffer overruns:
通常都是因为向一块固定内存数组写入了大于数组容量的数据,比如下面的代码:

char  array[10];
for(int i =0; i < 20; i++){
array[i] = 'x';
} 

这样一段代码就容易导致这一问题的发生

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值