免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2284 | 回复: 0
打印 上一主题 下一主题

遇到一个奇怪的汇编问题 请大家看看 很经典 的哦 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-01-04 15:23 |只看该作者 |倒序浏览
int addFunc(int,int);
int subFunc(int);

void main()
{

int x,y,z;
x= 1;
y=2;
z = addFunc(x,y);
}


int addFunc(int x,int y)
{
int value1 = 5;
int value2;

value2 = subFunc(value1);
return (x+y+value2);

}

int subFunc(int value)
{
return value--;
}

以上代码反汇编以后,如下: 有一些地方不明白  ,请大家帮忙看看
///////////////////////////////////////////////////////////////////////////

/* main Function */
0000000000000000 :

0: 27bdfff8 addiu $sp,$sp,-8

4: afbf0000 sw $ra,0($sp)

8: 0c000000 jal 0                 // 这样又跳回0,不就死循环了 ???  后面的代码如何执行?

c: 00000000 nop

10: 24040001 li $a0,1

14: 0c00000a jal 28            //同样问题,又跳到28,那后面的18,1c ,20 ,24  等指令 如何运行?

18: 24050002 li $a1,2

1c: 8fbf0000 lw $ra,0($sp)

20: 03e00008 jr $ra

24: 27bd0008 addiu $sp,$sp,8

28: 27bdfff0 addiu $sp,$sp,-16     // 从14跳过来 ,下面怎么执行? 返回18 ?还是向 2c 运行 ?

2c: afbf0008 sw $ra,8($sp)

30: afb10004 sw $s1,4($sp)

34: afb00000 sw $s0,0($sp)

38: 0080802d move $s0,$a0

3c: 00a0882d move $s1,$a1

40: 0c000019 jal 64          // 又是乱跳,从44 到 64 之间的指令怎么运行 ?

44: 24040005 li $a0,5

48: 02118021 addu $s0,$s0,$s1

4c: 02021021 addu $v0,$s0,$v0

50: 8fbf0008 lw $ra,8($sp)

54: 8fb10004 lw $s1,4($sp)

58: 8fb00000 lw $s0,0($sp)

5c: 03e00008 jr $ra

60: 27bd0010 addiu $sp,$sp,16

64: 03e00008 jr $ra

68: 0080102d move $v0,$a0
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP