3.3.2.1 加法指令

  ADD dst,src 加法指令(addition
  执行操作: (dst) ← (src)+(dst)

  ADC dst,src 带进位加指令(add with carry
  执行操作: (dst) ← (src)+(dst)+CF

  INC opr 加1指令(increment
  执行操作: (opr) ← (opr)+1

  ADD和ADC指令是双操作数指令,它们的两个操作数不能同时为存储器寻址方式,也就是说,除源操作数为立即数的情况外,源和目的操作数必须有一个是寄存器寻址方式。INC指令是单操作数指令,它可以使用除立即数方式外的任何寻址方式。

  ADD和ADC指令影响条件标志位(也称条件码),INC指令影响除CF外的其它条件码。条件码中最主要的是SF、ZF、CF和OF,加法运算对这四个条件码的设置方法如下:
  SF=1 加法结果为负数(符号位为1)
  SF=0 加法结果为正数(符号位为0)
  ZF=1 加法结果为零
  ZF=0 加法结果不为零
  CF=1 最高有效位向高位有进位
  CF=0 最高有效位向高位无进位
  OF=1 两个同符号数相加(正数+正数,或负数加负数),结果符号与其相反
  OF=0 不同符号数相加时,或同符号数相加,结果符号与其相同

  计算机在执行运算时,并不区别操作数是带符号数还是无符号数,一律按上述规则设置条件码,因此,程序员要清楚当时处理的是什么类型的数据。例如,当加法运算结果的最高有效位为1时,机器将SF置1。如果参加运算的是两个带符号数,那么和的最高有效位是符号位,SF置1说明结果是一个负数。如果参加运算的是两个无符号数,那么和的最高有效位也是数值位,此时SF置0或置1都失去了表示正负数的意义。

  对带符号数和无符号数,它们表示结果溢出的条件标志位也是不同的。上述OF位的设置条件显然只符合带符号数的溢出情况,OF=1表示运算结果是错误的。而无符号数溢出(运算结果超出了有限位的表示范围)时,表现为最高有效位产生进位,因此,CF=1是无符号数溢出的标志。另外,在双字长数运算时,低位字相加设置的CF,说明低位字向高位字有无进位的情况。