汇编语言初探
语法简介
汇编语法主要有两种:Intel语法和AT&T语法,Intel语法听起来不会让大家有什么疑问,很显然它是由Intel公司设计的,这里只简单说一下AT&T语法的起源,AT&T公司的前身是贝尔实验室,这里是C语言和Unix系统的诞生地,实验室的科学家们想让汇编语言的语法具有跨平台的特性(注意是语法跨平台,而不是说机器指令跨平台),于是抛开了Intel的语法规范,自己创立了一套汇编语法,这套规范在Unix、Linux和GNU的各种工具中得到了广泛的应用,这套语法用在x86平台下便被称为AT&T风格的x86汇编语言。
无论采用哪种语法,都要有支持该种语法的汇编器负责将汇编源代码翻译成x86机器指令,而Intel与AT&T风格的汇编语法差异,只存在于汇编代码层面,它们的主要差异如下表所示:
AT&T syntax | Intel syntax |
---|---|
寄存器前加% | 寄存器无需另加符号 |
立即数前加$ | 立即数无需另加符号 |
16进制立即数使用0x前缀 | 16进制的立即数使用h后缀 |
源操作数在前,目的操作数在后 | 目的操作数在前,源操作数在后 |
间接寻址使用小括号() | 间接寻址使用中括号[] |
间接寻址完整格式:%sreg:disp(%base,index,scale) | 间接寻址完整格式:sreg:[basereg + index*scale + disp] |
操作位数:指令+b、w、l、q | 指令+byte ptr、word ptr、dword ptr |
寄存器
从早期的x86到现在,体系结构从8位扩展到16位、32位、64位,现在每个寄存器的内部结构都有多种用途和含义,如下图所示:
在上面图中,%rax的低8位是8位寄存器%al, 相邻的8位是%ah,低16位是 %ax, 低32位是 %eax,整个64位是%rax。寄存器%r8-%r15也有相同结构,但命名方式稍有不同:
了解汇编语言
#include <stdio.h>
int main(int argc, char* argv[]){
printf("Hello %s!\n", "Richard");
return