汇编 - 基本语法


汇编程序可以分为三个部分 -

  • 数据部分

  • bss部分,以及

  • 正文部分

数据部分_

数据部分用于声明初始化数据或常量。该数据在运行时不会改变。您可以在本节中声明各种常量值、文件名或缓冲区大小等。

声明数据部分的语法是 -

section.data

bss部分_

bss部分用于声明变量声明 bss 部分的语法是 -

section.bss

正文部分_

文本部分用于保留实际代码。此部分必须以声明global _start开始,它告诉内核程序执行的开始位置。

声明文本部分的语法是 -

section.text
   global _start
_start:

评论

汇编语言注释以分号 (;) 开头。它可以包含任何可打印字符,包括空白。它可以单独出现在一行上,例如 -

; This program displays a message on screen

或者,与指令在同一行,例如 -

add eax, ebx     ; adds ebx to eax

汇编语言语句

汇编语言程序由三种类型的语句组成 -

  • 可执行指令或说明,
  • 汇编指令或伪操作,以及
  • 宏。

可执行指令或简单指令告诉处理器要做什么。每条指令由一个操作码(opcode)组成。每条可执行指令生成一条机器语言指令。

汇编程序指令或伪操作告诉汇编程序有关汇编过程的各个方面。它们是不可执行的,并且不会生成机器语言指令。

基本上是一种文本替换机制。

汇编语言语句的语法

汇编语言语句每行输入一个语句。每个语句都遵循以下格式 -

[label]   mnemonic   [operands]   [;comment]

方括号中的字段是可选的。基本指令由两部分组成,第一部分是要执行的指令名称(或助记符),第二部分是命令的操作数或参数。

以下是典型汇编语言语句的一些示例 -

INC COUNT        ; Increment the memory variable COUNT

MOV TOTAL, 48    ; Transfer the value 48 in the 
                 ; memory variable TOTAL
					  
ADD AH, BH       ; Add the content of the 
                 ; BH register into the AH register
					  
AND MASK1, 128   ; Perform AND operation on the 
                 ; variable MASK1 and 128
					  
ADD MARKS, 10    ; Add 10 to the variable MARKS
MOV AL, 10       ; Transfer the value 10 to the AL register

汇编中的 Hello World 程序

以下汇编语言代码在屏幕上显示字符串“Hello World” -

section	.text
   global _start     ;must be declared for linker (ld)
	
_start:	            ;tells linker entry point
   mov	edx,len     ;message length
   mov	ecx,msg     ;message to write
   mov	ebx,1       ;file descriptor (stdout)
   mov	eax,4       ;system call number (sys_write)
   int	0x80        ;call kernel
	
   mov	eax,1       ;system call number (sys_exit)
   int	0x80        ;call kernel

section	.data
msg db 'Hello, world!', 0xa  ;string to be printed
len equ $ - msg     ;length of the string

当上面的代码被编译并执行时,它会产生以下结果 -

Hello, world!

在 NASM 中编译和链接汇编程序

确保您已在 PATH 环境变量中设置nasmld二进制文件的路径。现在,按照以下步骤编译和链接上述程序 -

  • 使用文本编辑器输入上述代码并将其另存为 hello.asm。

  • 确保您与保存hello.asm 的目录位于同一目录中。

  • 要汇编程序,请输入nasm -f elf hello.asm

  • 如果有任何错误,系统会在此阶段提示您。否则,将创建一个名为hello.o的程序目标文件。

  • 要链接目标文件并创建名为 hello 的可执行文件,请输入ld -m elf_i386 -s -o hello hello.o

  • 输入./hello执行程序

如果您已正确完成所有操作,它将显示“Hello, world!” 屏幕上。