题目内容

以下是一段C语言程序代码:1 int add(int x,int y)2 {3 return x+y;4 }56 int caller( )7 {8 int t1=100;9int t2=200;10 int sum=add(t1,t2);11 return sum;12 }以下关于上述程序代码在IA-32上执行的叙述中,错误的是()。

A. 变量t1和t2被分配在caller函数的栈帧中
B. 传递参数时t1和t2的值从高地址到底地址依此存入栈中
C. add函数返回时返回值存放在EAX寄存器中
D. 变量sum被分配在caller函数的栈帧中

查看答案
更多问题

在第3题中的caller函数对应的机器级代码表示如下:1pushl %ebp2movl %esp, %ebp3subl $24, %esp4 movl $100, -12(%ebp)5 movl $200, -8(%ebp)6movl -8(%ebp), %eax7 movl %eax, 4(esp)8 movl -12(%ebp), %eax9 movl %eax, (%esp)10 call add11 movl %eax, -4(%ebp)12 movl -4(%ebp), %eax13 leave14 ret假定caller的调用过程是P,对于上述指令序列,以下叙述中错误的是()。

A. 第1条指令将过程P的EBP内容压入caller栈帧
B. 第2条指令使EBP内容指向caller栈帧的底部
C. 第3条指令将栈指针ESP向高地址方向移动,以生成当前栈帧
D. 从上述指令序列可以看出,caller函数没有使用被调用者保持寄存器

对于第3题的caller函数和第4题给出的对应机器级代码,以下叙述中错误的是()。

A. 变量t1和t2的有效地址分别为R[ebp]-12和R[ebp]-8
B. 变量t1所在的地址高(或大)于变量 t2所在的地址
C. 参数t1和t2的有效地址分别为R[esp]和R[esp]+4
D. 变量t1所在的地址低(或小)于变量 t2所在的地址

对于第3题的caller函数和第4题给出的对应机器级代码,以下叙述中错误的是()。

A. leave指令用于恢复EBP的旧值,并不会改变ESP的内容
B. 执行第10条指令的过程中,会把第11条指令的地址压入栈顶
C. 执行第11条指令时,add函数的返回值已经在EAX中
D. 变量sum的有效地址为R[ebp]-4

以下有关递归过程调用的叙述中,错误的是()。

A. 可能需要执行递归过程很多次,因而时间开销大
B. 每次递归调用都会生成一个新的栈帧,因而空间开销大
C. 每次递归调用在栈帧中保持的返回地址都不相同
D. 递归过程第一个参数的有效地址为R[ebp]+8

答案查题题库