将目标代码转换为汇编代码的过程,换句话说是将机器语言转换为汇编语言。
可执行文件(是机器语言)
反汇编器使用的汇编语言不同
通常使用的反汇编器不同获得的反汇编程序与源程序会存在有些不同,执行效果相同,但代码会发生改变,执行效果相同
反汇编是指将非汇编目标代码转变成汇编的过程.
你所看到的反汇编代码,其实是由C编译器将C语言代码直接编译成汇编代码的,并非由机器码反汇编成汇编.
这样做在调试阶段有非常大的意义,比如你写的代码,语法上一点错误都没有,但是逻辑上有了错误,往往你要找到这个逻辑错误是很难的,这时候在调试的时候单步执行反汇编代码就变的很有意义了,给你举个例子:将变量十进制码转成16进制,十进制码放在变量tmp中,如果代码这样写:
d=(tmp>>4)*10+tmp&0x0F;
假如你输入tmp变量存储的是十进制的23(存储为0x23),然后使用上句准换为16进制,那么d应该等于0x17,但实际上代码的结果却是0x07,原因就是虽然上句代码语法上没有错误,但是逻辑上有错,运算符’+‘的优先级是大于运算符’&'的,这就造成了运算结果出错,结合反汇编代码可以很容易查出这类错误.
反汇编和C代码中都可以设置断点,但调试反汇编可以获得更高的精度,因为一句C代码可能有数十条汇编代码组成,在C代码单步执行一次,可能执行了十几条汇编代码,而在反汇编界面单步调试,每次只执行一句汇编代码。
disassembly window 反汇编窗口
command window 命令窗口
call stack window 调用堆栈窗口
memory window 寄存器窗口
serial window 串口窗口
trace window 跟踪窗口
system viewer window 系统查看窗口
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)