一段汇编代码翻译成c语言的练习

本文通过一个具体的例子展示了如何将汇编代码转换为等效的C语言代码。函数`decode1`的汇编实现被分析并转换为C代码,最终得出的C函数实现了`*yp = *xp`, `*zp = *yp`, `*xp = *zp`的逻辑。通过反汇编验证,发现实际效果与预期一致,即三个指针所指的值都等于`*xp`。" 112887997,10548968,虚拟化vCPU配置指南:理解与实战,"['虚拟化技术', '系统优化', '资源管理', '服务器配置', 'CPU调度']
摘要由CSDN通过智能技术生成

题目是这样的:
有一个函数原型为

void decode1(int *xp,int *yp,int * zp);

函数的编译成汇编代码后如下:
1    movl 8(%ebp),%edi

2    movl 12(%ebp),%ebx

3    movl 16(%ebp),%esi

4    movl  (%edi),%eax

5    movl  (%ebx),%edx

6    movl  (%esi),%ecx

7    movl  %eax,(%ebx)

8    movl  %edx,(%esi)

9    movl  %ecx,(%edi)

 

要求写出等效的C代码。

 

分析过程:(中间伪代码)

edi  = xp

ebx = yp

esi  = zp

eax = *xp

edx = *yp

ecx = *zp

 

最后函数内的代码推测为:

*yp = *xp

*zp = *yp

*xp = *zp

 

用反汇编工具验证:
首先编写代码decode.c:

 

 gcc编译:gcc -O2 -c decode.c

 反汇编:objdump -d decode.o

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值