我在这个上运行了gcc-S:intmain(){printf("Helloworld!");}我得到了这个汇编代码:.file"test.c".section.rodata.LC0:.string"Helloworld!".text.globlmain.typemain,@functionmain:leal4(%esp),%ecxandl$-16,%esppushl-4(%ecx)pushl%ebpmovl%esp,%ebppushl%ecxsubl$20,%espmovl$.LC0,(%esp)callprintfaddl$20,%esppopl%ecxpopl%ebpleal-4(
我在这个上运行了gcc-S:intmain(){printf("Helloworld!");}我得到了这个汇编代码:.file"test.c".section.rodata.LC0:.string"Helloworld!".text.globlmain.typemain,@functionmain:leal4(%esp),%ecxandl$-16,%esppushl-4(%ecx)pushl%ebpmovl%esp,%ebppushl%ecxsubl$20,%espmovl$.LC0,(%esp)callprintfaddl$20,%esppopl%ecxpopl%ebpleal-4(
无论如何,这可以做到吗?我使用了objdump,但这不会产生我所知道的任何汇编程序都可以接受的汇编输出。我希望能够更改可执行文件中的指令,然后再对其进行测试。 最佳答案 我认为没有任何可靠的方法可以做到这一点。机器码格式非常复杂,比汇编文件更复杂。实际上不可能获取已编译的二进制文件(例如,ELF格式)并生成将编译为相同(或足够相似)二进制文件的源汇编程序。要了解这些差异,请将GCC直接编译到汇编器的输出(gcc-S)与objdump在可执行文件上的输出(objdump-D)进行比较。我能想到两个主要的并发症。首先,由于指针偏移等原因
无论如何,这可以做到吗?我使用了objdump,但这不会产生我所知道的任何汇编程序都可以接受的汇编输出。我希望能够更改可执行文件中的指令,然后再对其进行测试。 最佳答案 我认为没有任何可靠的方法可以做到这一点。机器码格式非常复杂,比汇编文件更复杂。实际上不可能获取已编译的二进制文件(例如,ELF格式)并生成将编译为相同(或足够相似)二进制文件的源汇编程序。要了解这些差异,请将GCC直接编译到汇编器的输出(gcc-S)与objdump在可执行文件上的输出(objdump-D)进行比较。我能想到两个主要的并发症。首先,由于指针偏移等原因
有人告诉我使用反汇编程序。gcc有内置的东西吗?最简单的方法是什么? 最佳答案 我不认为gcc有它的标志,因为它主要是一个编译器,但另一个GNU开发工具有。objdump采用-d/--disassemble标志:$objdump-d/path/to/binary反汇编如下:080483b4:80483b4:8d4c2404lea0x4(%esp),%ecx80483b8:83e4f0and$0xfffffff0,%esp80483bb:ff71fcpushl-0x4(%ecx)80483be:55push%ebp80483bf:89
有人告诉我使用反汇编程序。gcc有内置的东西吗?最简单的方法是什么? 最佳答案 我不认为gcc有它的标志,因为它主要是一个编译器,但另一个GNU开发工具有。objdump采用-d/--disassemble标志:$objdump-d/path/to/binary反汇编如下:080483b4:80483b4:8d4c2404lea0x4(%esp),%ecx80483b8:83e4f0and$0xfffffff0,%esp80483bb:ff71fcpushl-0x4(%ecx)80483be:55push%ebp80483bf:89
我想反汇编我拥有的可引导x86磁盘的MBR(前512个字节)。我已将MBR复制到一个文件中使用ddif=/dev/my-deviceof=mbrbs=512count=1对可以反汇编文件mbr的Linux实用程序有什么建议吗? 最佳答案 您可以使用objdump。根据thisarticle语法是:objdump-D-bbinary-mi386-Maddr16,data16mbr 关于linux-如何反汇编原始16位x86机器代码?,我们在StackOverflow上找到一个类似的问题:
我想反汇编我拥有的可引导x86磁盘的MBR(前512个字节)。我已将MBR复制到一个文件中使用ddif=/dev/my-deviceof=mbrbs=512count=1对可以反汇编文件mbr的Linux实用程序有什么建议吗? 最佳答案 您可以使用objdump。根据thisarticle语法是:objdump-D-bbinary-mi386-Maddr16,data16mbr 关于linux-如何反汇编原始16位x86机器代码?,我们在StackOverflow上找到一个类似的问题:
习题1(2)判断题AX被称为累加器,在8086程序中使用很频繁。(✓)指令指针IP寄存器属于通用寄存器。(✓)8086具有8个32位通用寄存器。(×)解析:8086的寄存器有8个16位通用寄存器、4个16位段寄存器、1个16位标志寄存器和1个16位指令指针寄存器8086编程使用逻辑地址,将其中段地址左移4位加偏移地址就是物理地址。(✓)Windows的模拟DOS环境与控制台环境是一样的。(×)解析:处理器的传送指令MOV属于汇编语言的执行性语句。(✓)汇编语言的语句由明显的4部分组成,不需要分隔符区别。(×)解析:汇编语言的语句一般都由分隔符分成的4个部分组成,有相似的两种格式,对应表达处理器
习题1(2)判断题AX被称为累加器,在8086程序中使用很频繁。(✓)指令指针IP寄存器属于通用寄存器。(✓)8086具有8个32位通用寄存器。(×)解析:8086的寄存器有8个16位通用寄存器、4个16位段寄存器、1个16位标志寄存器和1个16位指令指针寄存器8086编程使用逻辑地址,将其中段地址左移4位加偏移地址就是物理地址。(✓)Windows的模拟DOS环境与控制台环境是一样的。(×)解析:处理器的传送指令MOV属于汇编语言的执行性语句。(✓)汇编语言的语句由明显的4部分组成,不需要分隔符区别。(×)解析:汇编语言的语句一般都由分隔符分成的4个部分组成,有相似的两种格式,对应表达处理器