APSR 标志位一共有4 个,分别是N Z C V
N 标志位:运行完结果如果是正数、0、大于、等于该位置0,如果是负数或
者小于该位置1
Z 标志位:运行完结果如果是0 该位置1,如果不是0,该位置0
C 标志位:加操作发生进位或者减操作没有发生借位该位置1, 加操作没有
发生进位或者减操作发生借位该位置0
V 标志位:运行结果溢出该位置1,运行结果没有溢出该位置0
Z 标志位:指令运行完结果如果是0 该位置1,如果不是0,该位置0
假如R0 里面数据是0
MOVS R0,R0
那么指令执行结果R0 里面还是0,那么这个时候Z 标志位就是1
N 标志位:指令运行完结果如果是正数、0、大于、等于该位置0,如果是负数或
者小于该位置1
例如:
MOVS R0,#0
MOVS R0,R0
BEQ label
;用户代码1
label
;用户代码2
是否跳转?
BEQ 这条指令是Z=1 跳转,那么执行完MOVS R0,R0 之后,结果影响标志位Z=1,那么这条指令就发生了跳转,跳转到label 处执行用户代码2。
MOVS R0,R0 这条指令的执行结果影响标志位。因为R0 里面是0 ,所以MOVS
的执行结果R0 里面还是0 所以Z=1
MOV 和MOVS 这两条指令有什么区别呢?
带S 的指令执行结果会影响标志位,不带S 的指令执行结果不会影响标志位,
影响标志位主要体现在标志位的变化情况。