今天看汇编,
一个栈段最大可以设为多少?为什么?
分析:
这个问题显而易见,提出来只是为了提示我们将相关的知识融会起来。首先从栈操作指令所完成的功能的角度上来看,push、pop等指令在执行的时候只修改SP,所以栈顶的变化范围是0~FFFFH,从**栈空时候的SP=0**,一直压栈,直到**栈满时SP=0**;如果再次压栈,**栈顶将环绕**,覆盖了原来栈中的内容。所以一个栈段的容量最大为64 KB。
根据王爽的话 栈空时候的SP=0 栈满时SP=0,怎样理解
栈顶将环绕指什么
今天看汇编,
一个栈段最大可以设为多少?为什么?
分析:
这个问题显而易见,提出来只是为了提示我们将相关的知识融会起来。首先从栈操作指令所完成的功能的角度上来看,push、pop等指令在执行的时候只修改SP,所以栈顶的变化范围是0~FFFFH,从**栈空时候的SP=0**,一直压栈,直到**栈满时SP=0**;如果再次压栈,**栈顶将环绕**,覆盖了原来栈中的内容。所以一个栈段的容量最大为64 KB。
根据王爽的话 栈空时候的SP=0 栈满时SP=0,怎样理解
栈顶将环绕指什么
栈顶环绕实际就是计算机中的数的运算的问题,当一个16位的数为ffffh的时候这个数最大了,再将ffffh加1会得到0。
所以sp是指向栈顶元素,当栈为空的时候,栈内没有元素,那么就要指向栈的最后一个位置还要往后一位,既ffffh+1=0。