汇编指令
汇编代码,高级语言-》汇编代码-》二进制-》计算机执行
高级语言只能转换成一种汇编代码,汇编代码可能转换成多种高级语言,过程不可逆,汇编代码对应二进制是一样的
CPU和外接的交互是通过三条总线,地址总线,数据总线,控制总线
地址总线:8086的总线是20根,寻址能力是2^20=1M,M是大小,MB是数据量,1M = 1024K = 1024*1024B
数据总线:数据总线的宽度决定了CPU单次传输的最大数据,8086的数据总线宽度16,单次能够传递2个字节,一个字节是8位,
控制总线:控制总线的宽度决定CPU的控制能力,有多少种控制CPU通过控制总线得到命令,数据总线获得内存地址,读写数据的信息数据总线获得
寄存器:CPU存储信息的地方,程序员对CPU的控制通过代码和修改寄存器的数据,8086寄存器是16位
寻址方式:8086寄存器是16位,小于地址总线的20位,存储地址是不够的,采用段地址的方式,把内存分成几段,段地址*16+偏移地址
段寄存器:CS (Code Segment):代码段寄存器,DS (Data Segment):数据段寄存器,SS (Stack Segment):堆栈段寄存器,ES (Extra Segment):附加段寄存器。
程序读取内存条上的数据需要寄存器提供地址,读取地址是从低地址往高地址读取,
代码段寄存器:CS段地址,IP偏移地址
mov ax, 2000H
mov cs, ax //CS = 2000H IP = 0H
mov ax 2000H //ax = 2000H*16+IP内存的值,IP = IP + 3
jmp指令:jmp指令是操作段寄存器的指令
jmp 1000H:3H //CS:1000H IP:003H
jmp 3H //CS为原来的值 IP:003H
数据段寄存器:mov bx, 1000H //1000H的值赋给bx
mov ds, bx //bx的值赋给数据段
mov al, [0] //数据段偏移量为0的数据赋给,ax的第八位al
mov [0], al //al的值,写入数据段偏移量为0的地址
add ax, 8 //ax = ax + 8
sub ax, 8 //ax = ax - 8
堆栈段寄存器:SS段地址,SP偏移地址,push入栈高地址向低地址,pop出栈低地址向高地址
堆栈使用前需要配置SS和SP,mov ax, 2000H mov SS, ax mov SP, 0H
8086编程代码:assume cs:code
code segment
mov ax, 1122h
mov bx, 3344h
add ax, bx
mov ah, 4ch
int 21h
code ends
end
伪指令assume,指定代码段,segment段代码开始,ends段代码结束,end整个代码结束
mov ah, 4ch int 21h程序中断
loop指令:mov cx, 5 //loop指令的循环次数是根据cx来确定的
star: add ax, ax //首先执行标记star
loop star //检查cx是否大于零,大于零就跳到标记star执行,cx--
ps:如果指令的标记是star那么引用标记是引用的值,如果标记是star:那么引用的是标记的地址,如果非要用star,可以使用offset star来获取地址
指令db,dw: db(define byte) 自定义字节
dw(define word)自定义字
db 20 dup(1) 定义20个1的字节
call和ret指令:call调用标记号的代码
将call下面一条代码的地址入栈
跳转标记号地址的代码执行
ret指令将栈顶的地址赋值给IP指针
ps:call和ret指令调用函数,进入函数体执行完毕后返回,ret不是return,只是返回执行代码的地方,return是返回值。
bp和sp:从栈里取数据ss: [sp + 2]这样是不行的,语法问题,必须将sp赋值给bp才可以
ret 6将栈顶指针加6,出栈的意思
调用函数过程:将函数下一条指令的地址入栈,sp赋值给bp
bp入栈起保护作用,如果函数调用函数,bp会乱跑
如果有局部变量,sp会减一段区域供局部变量使用,访问使用bp
保护寄存器
业务逻辑代码
恢复寄存器
恢复sp,一般指向bp
入栈保护的bp恢复
ret
oc代码汇编的优化:debug模式会显示全部的调用代码
release模式会优化c语言的调用代码,返回值会直接赋给,汇编代码不
会再调用具体过程,但是oc代码不行