标志寄存器-神秘的第十四个寄存器flag
axbxcxdx
sidi
bpspip
csssdses
flag
按位起作用
特殊之处 OF(overflow)1:ov ; 0:nv -溢出
DF (direction) 1DN 0UP 方向
SF sign符号 ng pl 1 negative 0positive
ZF zero零值 zr / nz zero / notzero
PF Parity奇偶数 1pe 0 po odd/even
CF carry进位
直接访问flag的方法pushf popf
ZF 结果是零的话 寄存器就zf=1; 很多如add sub mul都会影响zf
PF parityflag - 记录指令执行后结果的所有二进制位中1的个数
1的个数为偶数个 pf=1
SF - 结果看作有符号数 结果为负数sf=1;
见机行事 看作正数负数
CF 进位标志 CF=1 有进位或借位----针对无符号数
对比CF–针对无符号数;OF-针对有符号数
综合 一条指令可以带来多少标志寄存器的变化
带进位的加法指令adc用cf位记录进位值 adc ax,bx-------就这个机制 -感觉别扭 但是往后看大数相加 合理
adc指令应用 大数相加---------分组-低十六位-高十六位 ;地位产生的进位通过adc解决了!
128位数相加
特别注意:思考!
不可以!!!还有个目的是cf清零
不可以!!! inc di不会影响flag 而add di2 会影响
sbb—带借位减法指令 sbb ax bx
cmp比较指令 cmp 操作对象1,操作对象2-------二者相减结果不保存----------指令执行后将对flag产生影响—以此确定比较结果
无符号数 例如 相等:zf=1 ; 不等于 zf=0 ;小于:cf = 0;
条件转移指令 jxxx标号-----套路je:jump equal 结果相等跳转
条件转移指令的使用—直接考虑cmp和jxxx指令配合出来的逻辑含义就可以了----------例如:cmp ah,bh je sadd ah,bh jmp short ok
条件转移指令的应用–本质 转移–修改ip; 和cmp配合使用cmp改变标志位
双分支结构的实现—对比c语言
统计8的数量
DF方向标志位和段传送—
原本方法:mov ax ,【si】
mov【di】,ax
add si,2
add di,2
更简洁方法
DF=0:每次操作后si di 递增
在串处理指令中,控制每次操作后si di的增减 ; 对DF位进行设置的指令:cld df=0;std df=1;
rep指令 —根据cx重复执行后面的指令-------常常与串传送指令搭配 rep movsb
中断—导学------精华
移位指令
逻辑左移:影响cf 和cf一起左移 补零
循环左移 影响cf 但是后面也得加上移出去的那个数
算数左移
shl
sal
rcl
惯常用法:逻辑左移乘法
显示的原理—屏幕的内容=显存中的数据
显示缓冲区 每个两个字节,一行八十个-----一行160字节
显示想显示的东西 不同颜色
标号
改进
改进:标号法a: db 1,2,3,4 ; 然后 用这个数据 就直接 mov si ,offset a ; 随后 做各种操作就直接cs:【si】
更加改进: 去掉:的数据标号 adb 1,2,3,4,后面就直接 mov si,0 ;然后直接操作 a【si】像数组一样
a db 1,2,3,4,5,6,7,8; b dw 0 其中 b代表地址为code:8,长度为字的内存单元—还表明了长度!
常用方式 数据段中用数据标号
注意:a db 1,2,3,4,5,…---------a相当于保存开始的地址—也就是指针; c dw offset a,offset b; c还是指针,相当于指针的指针;
数据的直接定址表----最简方案 查表 做成一个表 直接要啥给啥
利用表 在两个数据集合之间建立一种映射关系
定址表 – 空间换时间
代码的直接定址表—
中断-内(INT)-外(键盘等)
0: 除法错误div除法溢出;1:单步 4:into 溢出中断; n INT指令 下面举例
13,10表示回车换行; $结束符号
int 21h中断—然后看ax里面,ax里面是ah是9,执行九号操作 去显示那个ds:dx–然后是里面是显示helloworld
hello world的写法
cpu接到中断信息 去执行中断处理程序–需要改变cs:ip------根据中断信息去找中断处理程序-----查中断向量表
8086cpu的中断向量表—找cs:ip
案例 0号中断
中断过程—cpu硬件自动完成,用终端类型码找到中断向量,并用它设置cs:ip80
8086CPU中断过程1.从中断中获取中断类型码2.标志寄存器的值入栈----中断过程重要改变标志寄存器的值,需要先行保护。3设置标志寄存器的第八位tf和第九位if的值为0.4cs内容入栈5ip内容入栈6从中断向量表中读取中断处理程序的入口地址,设置cs:ip
编制中断处理程序----常驻内存
自己编织中断处理程序–除法错误为例
do0子程序–自己制作
把自己的程序安装到内存里面 再把这个地址写道中断向量表
用内存复制的那个程序指令----从si 复制到 di----串传送-----长度–offset do0end-offset do0
设置中断向量表 就是把内存那个地方改一下数值
小结!!!
常驻内存程序编制-----套路-----由自己安装到内存的指定区域的代码和数据
如果是haike呢–她骗人安装他的程序,然后运行。他的程序把自己的脏东西串传送到内存某个地方,然后触发中断,让自己的脏东西获得cpu运行,然后就可以显示自己的东西了。或者简单点,别人运行他的程序,他就直接开始干活了,脏东西挥洒了
单步中断–寄存器flag—TF trap flag ,tf=1每条指令执行后产生陷阱,由系统控制计算机,当tf=0,cpu正常工作,不产生陷阱
if interrupt flag 当if=1,允许cpu相应可屏蔽中断请求,if=0关闭中断
中断不响应情况
原因–设置ss:sp强制要求连续完成 以此保证栈的准确正确