标志寄存器-神秘的第十四个寄存器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;