posts - 90,comments - 0,views - 12584

汇编程序可以分成3个区域

  • data section: 用于声明初始化的数据或者常量,运行时不会更改
    section .data
  • bss section: 用于声明变量
    section .bss
  • text section: 用于保存实际的代码。这个部分必须以声明global _start开始,它告诉内核程序从哪里开始执行。
section .text
    global _start
_start:

用分号开头表示注释
; 这是注释

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

  • 可执行指令直接告诉处理器要执行的操作。

每条可执行指令由操作码(opcode)组成,操作码指定了具体的操作,例如加法、乘法、加载数据等。每条可执行指令生成一条机器语言指令,这是处理器能直接执行的指令。

  • 汇编器指令指导汇编器如何处理源代码及其生成的输出。

这些指令不是可执行的机器指令,它们告诉汇编器如何处理符号表、生成的代码布局、如何分配存储等。例如,.data 指令用于指示开始数据段,而 .text 指令用于指示开始代码段,这些指令在汇编器处理过程中起到重要的控制作用。

  • 在源代码级别进行文本替换。

宏是一种文本替换机制,允许程序员定义一段代码片段,然后通过简单的标识符来调用它。宏在编译器预处理阶段展开,将宏的调用替换为宏定义的实际文本。它们不生成机器语言指令,而是在源代码级别进行文本替换,帮助程序员简化代码、增强可读性和维护性。

汇编语言语句的语法:
[label] instruction [operands] [;comment] ,方括号内容可选

在nasm中编译和连接汇编程序:

  1. 汇编程序文件编译成目标文件
    nasm -f elf64 hello.asm -o hello.o

    -f elf64 指定生成64为的ELF格式的目标文件

  2. 链接目标文件生成可执行文件
    ld (-m elf_x86_64) hello.o -o hello

    括号可选,只是保证生成正确格式的可执行文件

  3. 运行可执行文件
    ./hello

posted on   Dylaris  阅读(84)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示