汇编cmp比较指令详解
刚刚看到了cmp指令,一开始有点晕。后来上网找了些资料,终于看明白了,为了方便初学者,我就简单写下我的思路吧。高手绕过,谢谢!
cmp(compare)指令进行比较两个操作数的大小
例:cmp oprd1,oprd2
为第一个操作减去第二个操作数,但不影响第两个操作数的值,它影响flag的CF,ZF,OF,AF,PF.
我们怎么判断大小呢?
若执行指令后:ZF=1,则说明两个数相等,因为zero为1说明结果为0.
当无符号时:
若CF=1,则说明了有进位或借位,cmp是进行的减操作,故可以看出为借位,所以,此时oprd1<oprd2;
CF=0,则说明了无借位,但此时要注意ZF是否为0,若为0,则说明结果不为0,故此时oprd1>oprd2.
当有符号时:
若SF=0,OF=0 则说明了此时的值为正数,没有溢出,可以直观的看出,oprd1>oprd2;
若SF=1,OF=0 则说明了此时的值为负数,没有溢出,则为oprd1<oprd2;
若SF=0,OF=1 则说明了此时的值为正数,有溢出,可以看出oprd1<oprd2;
若SF=1,OF=1则说明了此时的值为负数,有溢出,可以看出oprd1>oprd2;
最后两个可以作出这种判断的原因是,溢出的本质问题:
两数同为正,相加,值为负,则说明溢出
两数同为负,相加,值为正,则说明溢出
故有,正正得负则溢出,负负得正则溢出
很简单的一条指令,初学者看看,我感觉我写的还挺详细的,哈哈……
补充: 两数相减,同号,则不溢出;两数为异号,结果与减数符号相同,则溢出。
岑雨同学: 如果不管这个问题可不可以的,代码也能正常运行,会有什么问题嘛
CSDN-Ada助手: 推荐 Python入门 技能树:https://edu.csdn.net/skill/python?utm_source=AI_act_python
xiaoyuetianxin: 好清晰,一下就懂了
AlgoRythmMistress: 文章清晰阐述FedProx算法,强调了数据隐私保护和安全性,详细解释了采样和直接平均梯度估算,以及通过修改目标函数加入正则化项的训练方法。语言精准,逻辑清晰,大大对联邦学习的理解深入,让人一目了然,赞!
做而论道_CS: 如果是 16 位二进制数, 其数值范围是:16 个 0 ~ 16 个 1。 相当于十进制:0 ~ 65535。 如果出现进位,就是:2^16 = 65536。 那么,加上 1111 1111 1111 1111 (十进制为 65535),再减去进位,这就是 “-1 ” 了。 所以,+65535,舍弃进位 (65536),就是 “-1 ”。 同理,+65534,舍弃进位 (65536),就是 “-2 ”。 。。。 。。。 +32768,舍弃进位 (65536),就是 “-32768 ”。 这就到达了下限。 如果继续加: +32767,是不会出现进位的。 所以,0 ~ 32767,只能当正数使用。