写入正在运行的汇编程序

use*_*522 2 assembly

我有一个关于汇编编程的一般问题.

编写高级语言时,编译器会获取复杂的高级指令,并将它们分解为一堆二进制的机器级指令.

由于您在机器代码中编写,因此汇编不需要此.

但是,你如何实际获得你写入二进制文件的代码?我的意思是你显然是在文本编辑器中写作.你用什么来将这些指令放入二进制程序?

pax*_*blo 6

由于您在机器代码中编写,因此汇编不需要此.

实际上,除非您输入十六进制或二进制数字,否则您不会使用机器语言进行编程.汇编语言是mov $1, %eax底层机器代码(例如53 32 01)的符号表示(例如).通常有一个一对一的装配到机器代码的映射,但并不总是如此.

在如何将汇编语言转换为CPU可以运行的机器代码方面,您使用汇编程序,它基本上只是汇编语言的"编译器".

例如,您可以查看Microsoft的masmNetwide汇编程序nasm,GNU自己gas以及许多其他程序.


举例来说,这里有一个成绩单,显示如何组装一个短程序(可能有错误,我实际上没有尝试链接和运行它,但这与我试图在这里得到的点无关).首先,让我们展示汇编源代码:

pax> cat testfile.nasm
section .text
         mov   ah, 09h        ; int 21/09 write string
         mov   dx, msg
         int   21h

         mov   ax, 4c00h      ; int 21/4c exit
         int   21h

section  .data
msg:     db   'Hello, world.'
         db   10, '$'
Run Code Online (Sandbox Code Playgroud)

然后我们将它与它组装nasm并显示生成的目标文件:

pax> nasm -f elf testfile.nasm
pax> objdump -ds testfile.o

testfile.o:     file format elf32-i386

Contents of section .text:
 0000 b40966ba 0000cd21 66b8004c cd21      ..f....!f..L.!
Contents of section .data:
 0000 48656c6c 6f2c2077 6f726c64 2e0a24    Hello, world..$

Disassembly of section .text:

00000000 <.text>:
   0:   b4 09                   mov    $0x9,%ah
   2:   66 ba 00 00             mov    $0x0,%dx
   6:   cd 21                   int    $0x21
   8:   66 b8 00 4c             mov    $0x4c00,%ax
   c:   cd 21                   int    $0x21
Run Code Online (Sandbox Code Playgroud)

您可以看到汇编源文件已转换为等效的机器代码.该objdump方案已拆开它,你回你,但实际的机器代码汇编语言是在简单的二进制信息.text部分:

b4 09 66 ba 00 00 cd 21 66 b8 00 4c cd 21
Run Code Online (Sandbox Code Playgroud)