码迷,mamicode.com
首页 > 其他好文 > 详细

汇编 影响标志位的运算

时间:2016-10-31 21:50:32      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:and   条件   span   指令   开心   round   加法   bsp   ack   

 今天翘了毛概课,在宿舍里盖着小毛毯做汇编作业,遇到一个题目是给出一组指令,问每一步指令完成后,标志位是什么

什么运算会改变标志位呢?在网上查了查

(1)加法指令:ADD、ADC、INC、XADD除了INC不影响CF标志位外,都影响条件标志位。

CF、ZF、SF、OF

CF最高位是否有进位

DF若两个操作数符号相同而结果符号与之相反OF=1,否则OF=0.

(2)减法指令:SUB、SBB、DEC、NEG、CMP、CMPXCHG、CMPXCHG8B

前六种除了DEC不影响CF标志外都影响标志位。CMPXHG8B只影响ZF。

CF说明无符号数相减的溢出,同时又确实是被减数最高有效位向高位的借位。

OF位则说明带符号数的溢出

无符号运算时,若减数>被减数,有借位CF=1,否则CF=0.

OF若两个数符号相反,而结果的符号与减数相同则OF=1.否则OF=0.

(3)乘法指令:MUL、IMUL

MUL:如果乘积高一半为0,则CF和OF位均为0,否则CF和OF均为1.

IMUL:如果高一半是低一半符号的扩展,则CF位和OF位均为0,否则就均为1.

(4)除法指令:DIV、IDIV
对所有条件位均无定义。

(5)逻辑指令:AND、OR、NOT、XOR、TEST

NOT不允许使用立即数,其它4条指令除非源操作数是立即数,至少要有一个操作数必须存放在寄存器中。另一个操作数则可以使用任意寻址方式。

NOT不影响标志位,其余4种CF、OF、置0,AF无定义,SF、ZF、PF位看情况而定

定位扫描指令:BSF正向位扫描、BSR反向位扫描

源操作数可以是除立即数以外的任一种寻址方式,目的操作数必须是寄存器,影响ZF位。
 天气越来越冷了,穿的暖暖的会更开心哦~冬天快乐~

汇编 影响标志位的运算

标签:and   条件   span   指令   开心   round   加法   bsp   ack   

原文地址:http://www.cnblogs.com/qingchen1996/p/6017204.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!