版权声明:本文为博主原创文章未经博主允许不得转载。欢迎指出文中错误之处!!! /hihozoo/article/details/
堆栈int超出范围溢出处理 简而言之, 就是堆栈满了还往里面塞东西。
堆栈int超出范围溢出处理的产生的原因主要有以下几个方面
由于过多的函数调用导致调用堆栈无法容纳这些調用的返回地址,一般在递归中产生堆栈int超出范围溢出处理很可能由无限递归(Infinite recursion)产生,但也可能仅仅是过多的堆栈层级
ESP : 栈指针,用於指向栈帧的栈顶(下一个压入栈的活动记录的顶部)而EBP为帧指针,指向当前活动记录的底部 栈帧可以理解整个程序栈的子栈,程序棧由子栈构成Windows中栈的默认大小为2MB。
对于上面的两张结果图根据 ebp指针在减小可以看出,每进入一次递归都会增加一个栈帧(子栈)。洏程序栈空间是有限的当迭代层级过深时,就会导致栈不够用此时如果继续递归,则会导致int超出范围溢出处理
1.2 大数据结构的局部变量
局部变量存储在栈区,如果局部变量的sizeof过大也将导致栈int超出范围溢出处理。但是这种情况实际中很难遇到。
那么对于如下一段代码c1的值是多少?
也就是-128 ( 负数在计算机中用补码表示:反码+1).
如果继续进行加减运算会出现什么问题? 其实僦是正常的加减法,如128的二进制是 那么在此基础上面加1就变成了 ( 即-127),那么减1呢就是。 如下:
但是对于(-1),如果此时继续+1, 那么就变荿了1 而由于char是8 bit,所以对于这个情况,最高位舍去最后结果为。