汇编基础笔记一

汇编指令

汇编代码,高级语言-》汇编代码-》二进制-》计算机执行

高级语言只能转换成一种汇编代码,汇编代码可能转换成多种高级语言,过程不可逆,汇编代码对应二进制是一样的

CPU和外接的交互是通过三条总线,地址总线,数据总线,控制总线

地址总线:8086的总线是20根,寻址能力是2^20=1M,M是大小,MB是数据量,1M = 1024K = 1024*1024B

数据总线:数据总线的宽度决定了CPU单次传输的最大数据,8086的数据总线宽度16,单次能够传递2个字节,一个字节是8位,

控制总线:控制总线的宽度决定CPU的控制能力,有多少种控制CPU通过控制总线得到命令,数据总线获得内存地址,读写数据的信息数据总线获得

寄存器:CPU存储信息的地方,程序员对CPU的控制通过代码和修改寄存器的数据,8086寄存器是16位

汇编基础笔记一_第1张图片

寻址方式: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代码不行

你可能感兴趣的:(汇编基础笔记一)