
目前的反编译软件,只存在将机器指令码反汇编成汇编代码,不存在将汇编代码反编译成C语言的,因为汇编代码是低级语言,最接近于机器码(具体可查看不同硬件平台的技术资料),每条汇编指令都对应一个固定的机器码,这样进行反汇编是可行的,而C语言属于高级语言,编译器没有能力将汇编语言翻译成C或更高级的语言。
不同编译器嵌入汇编的方式不一样,具体如下:
一、Turbo
C ,
也就是所说的TC。
1、使用预处理程序的伪指令#asm和#endasm,#asm用来开始一个汇编程序块,而#endasm指令用于该块的结束。
参考代码:
int mul(int a, int b)
{
/汇编开始/
#asm
mov ax,word ptr 8[bp]
imul ax word ptr 10[bp]
#endasm
/汇编结束。/
}
2、使用asm语句:
格式:asm<汇编语句>
参考代码:
int mul(int a, int b)
{
asm mov ax,word ptr 8[bp]
asm imul ax word ptr 10[bp]
/
每个asm对应一句汇编
注意结尾不需要分号
/
}
二、VC++/VS
格式:
__asm
汇编指令
[
;
]
__asm
{
汇编指令
}
[
;
]
asm前面是两条下划线,后面的方括号内容表示分号可有可无。
使用方法:
1、一条一条地用:
__asm mov al, 2
__asm mov dx, 0xD007
__asm out dx, al
每行一条汇编,
可以有分号,也可以没有。
2、组成一块地用:
__asm {
mov al, 2
mov dx, 0xD007
out dx, al
}
整体作为一个汇编代码块。
3、也可以将多条汇编写在一行:
__asm mov al, 2 __asm mov dx, 0xD007 __asm out dx, al
三、GNU
GCC
GCC对汇编的支持是最丰富的,简单介绍如下:
1、
用到的关键字:
“__asm__”
表示后面的代码为内嵌汇编,“asm”是“__asm__”的别名。
“__volatile__” 表示编译器不要优化代码,后面的指令保留原样,“volatile”是它的别名。
括号里面是汇编指令。
内嵌汇编语法如下:
__asm__(
汇编语句模板:
输出部分:
输入部分:
破坏描述部分)
一个简单的汇编模板:
int a=10,b;
asm("movl %1, %%eax;
movl %%eax, %0;"
:"=r"(b) /输出部/
:"r"(a) /输入部/
:"%eax" /毁坏部/
);
表示C语言里的“b=a;”。
里边r表示使用任意寄存器,%0、%1表示使用两个寄存器,一般只能%0~%9共十个 *** 作数,按输入输出部变量出现顺序进行映射。
寄存器用两个百分号,是因为使用了%0%1这些数字使百分号有了特殊意义,所以在 *** 作数出现的寄存器必须用双百分表示。
毁坏部里边的%eax表示eax寄存器在汇编代码块执行过程中会被改写,在执行前要保护好,这是提交给编译器决定的。
通过C语言函数形式封装汇编语言程序段,而后就可完全按照C语言函数的形式调用。这种方法保证了子程序段与主程序衔接的完全适配,使用简便。使用方法如下:
用低划线_后接关键字asm指示后面的语句是汇编语句。汇编语句既可以是单句,例如__asm mov bx,1;也可以是复合语句,即,用花括号对包含的多条单句,例如:
__asm
{ mov al, 3
mov dx, 0xE008
add ax,dx
}
在语法规则中,这些语句与C语言的语句完全等价。因此,可以直接进行编译。
以上就是关于将汇编代码转换为c语言全部的内容,包括:将汇编代码转换为c语言、如何把汇编程序嵌入到C语言中、用汇编语言编写子程序后如何调用等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)