我有一个关于汇编编程的一般问题.
编写高级语言时,编译器会获取复杂的高级指令,并将它们分解为一堆二进制的机器级指令.
由于您在机器代码中编写,因此汇编不需要此.
但是,你如何实际获得你写入二进制文件的代码?我的意思是你显然是在文本编辑器中写作.你用什么来将这些指令放入二进制程序?
由于您在机器代码中编写,因此汇编不需要此.
实际上,除非您输入十六进制或二进制数字,否则您不会使用机器语言进行编程.汇编语言是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)