还是那句话,CPU能运行的只有本地代码(机器语言)程序,其内容是数值的罗列。
汇编语言
在本地代码程序中,内容只是数值的罗列,人类无法识别。
想法:在各本地代码中,附上表示其功能的英文缩写。
比如:执行加法运算的本地代码中,加上add(addition的缩写);比较运算的本地代码中,加上cmp(compare的缩写)。可以有助于理解。
这些缩写称为助记符,使用这些助记符的编程语言就是汇编语言。汇编文件后缀.asm.汇编语言和机器语言是一一对应的。
汇编语言-->机器语言:汇编。由汇编器完成。
机器语言-->汇编语言:反汇编。由反汇编程序完成。
C语言等高级编程语言和机器语言不是一一对应的,因而反编译比反汇编困难。
通过编译器,将其他编程语言代码转变为汇编代码
除了将本地代码通过反汇编转换得到汇编语言代码,大部分的C语言编译器,都可以将C语言代码转换为汇编代码。
程序栗子:
#include <stdio.h>
void main(){
//求和
int addNum(int a, int b){
return a+b;
}
//调用
void myFunc(){
int c;
c = addNum(123,456);
}
}
仅编译而不链接,生成.asm汇编文件。
汇编语言的源代码里有什么?
汇编语言的源代码=转换成机器语言的指令(操作码)+针对汇编器的伪指令
伪指令:将程序构造和汇编方法指示给汇编器,本身不会转换为本地代码。
汇编语言的真正语法:操作码+操作数
操作码:指令动作。操作数:指令对象。
CPU中的寄存器的名称会通过汇编语言的源代码指定给操作数。
汇编语言的几个主要操作码
mov指令
栈操作:push() 和 pop()
push指令和pop指令都只有一个操作数,表示push或pop的是什么。
汇编语言函数调用
函数内部处理
汇编语言中的全局变量和局部变量
全局变量使用的内存空间被始终确保
_DATA 段定义中包含了没有初始化定义的全局变量。
_BSS 段定义中包含了已经初始化定义的全局变量。
局部变量使用的内存空间在寄存器中或者在栈中
汇编语言中的循环语句
C语言:for语句,循环计数器初始值i=0 + 循环继续条件(i<n)+ 循环计数器更新(i++)来完成一个循环语句。
汇编语言:通过比较指令cmp 和 跳转指令jl 来完成一个循环语句。
汇编语言中的条件分支语句
汇编语言中,同样适用cmp比较指令和jl等跳转指令来完成一个条件分支语句。