第9章(转移指令):
8086转移指令:
无条件转移指令,条件转移指令,循环指令,过程,中断
offset(伪指令):取得标号偏移地址(也就是要配合标号使用))取得值相当于一个常数(不能直接给段寄存器)
jmp(无条件跳转):可以修改ip也可以修改cs和ip
(基于偏移) jmp short 标号:修改ip机器指令不包含目的地址,包含偏移地址
short 8位的转移(-128~127),near ptr 16位的转移(-32769~32767)
(基于目的地址)jmp far ptr 标号
(基于寄存器)jmp 16位寄存器(存有转移目的地址)
(基于内存)jmp word ptr 内存单元地址(存有转移目的地址)
word段内转移 ,dword段间转移
jcxz(有条件跳转指令)(都是短转移(基于偏移(-127~128)))
jcxz 标号(若cx=0则转移到标号处)
loop(短转移)循环cx次 loop会先对cx-1再判断cx与0的关系(基于偏移(-127~128))
短跳转越界会报错。
实际操作暴露的问题:
1.32位方式cs在后,ip在前
2.不同数据段偏移地址互不影响
3.数据不能直接赋给内存
4.实验8原理,标号代表的是偏移地址,在执行之前得到并转化,所以向上跳。
实验9(彩色打印):
B8000H~BFFFFH为显示缓冲区,分8页,默认显示第一页(B8000H~B8F9FH)
一行共160个字节,两个字节表示一个字符(偶地址放ascii,奇地址放属性各1字节)(从0到159)
属性: | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
BL R G B I R G B
闪烁 背景 高亮 前景
编程暴露的问题:1.ss,cs值不能直接改变,不能有像mov ss,ax这种
2.初始化应在入栈,循环(标号)前
3.注意一个字占两个内存单元,add bx,2而不是inc bx
第10章(call和ret):
ret指令:用栈中命令修改ip(出栈)(ip先正常加再被覆盖)
retf指令:依次出栈ip和cs
call指令:将当前ip(call指令下一个指令开始地址)或cs和ip入栈,转移(非短转移)
基于标号: (段内)call 标号:ip入栈后到标号处执行
(段间)call far ptr 标号 :cs入栈,ip入栈后到标号处执行
基于寄存器:(段内) call 16位寄存器
基于内存:(段内)call word ptr 内存单元地址(ip入栈后执行内存单元中的地址)
(段间)call dword ptr 内存单元地址(存放顺序cs ip)(csip入栈后执行内存单元中的地址)
call+ret实现子程序:call和ret配对
call到mov ax,4c00h int 21h后,再用ret返回回来就可以实现子程序调用
子程序参数和结果需要寄存器较少时存放在寄存器中(参数寄存器,结果寄存器)
参数和结果较多时将批量数据存在内存中或栈中,首地址放在寄存器中
发生寄存器冲突(不同操作依赖同一寄存器)使用栈push pop来避免冲突
mul:乘法命令(mul 寄存器;mul byte ptr 内存地址;mul word存在 ptr 内存地址)
8位*8位(结果放入ax)默认al*
16位*16位(结果放入dx+ax)默认ax*
实验代码不难,鱼c论坛上都有(判断0用cx+jcxz的方法)
检测点暴露的问题:1.sp和bp默认段寄存器都是ss
2.0B8000h部分是显卡地址是动态变化的,debug跟踪会有问题
3.子程序设计时开始入栈,ret出栈以提高通用性
网友评论