我听说x86比较指令:cmp x, y
进行减法并根据结果设置各种标记。
现在,如果我只想测试两个操作数是否相等怎么办?不能做XOR而不是减法要快得多吗?我的问题是,是否有一个指令与XOR进行比较,以判断两个操作数是否相等?也许它看起来像这样:cmpeq x, y
或cmpxor x, y
。
我猜想如果我只想测试相等性,那么使用cmpxor
会比cmp
更快,后者会进行减法。是否有像cmpxor
这样的指令可以让我加速?
我还想说,我知道xor
会设置zero flag
。但如果我执行xor x, y
,则会更改x
。我不希望这样。我想要一个比较指令,只留下两个操作数。
答案 0 :(得分:12)
XOR,SUB,CMP,TEST等基本机器操作都非常简单,因此它们都能非常快速地运行。它们还设置相同的条件码位。从比较相等的角度来看,这些都将Z位设置为相同的方式;其他位设置不同,因为这些操作计算不同的结果。
对于x86 CPU,这些CPU的执行时间没有差别,因为它们都使用相同的芯片通路。因此,您可以在不计算性能的情况下使用它们来计算您想要的答案。 (从技术上讲,SUB应该比XOR更长,因为进位必须“波动”所有位,而XOR是逐位并行的.CPU设计人员已经找到了构建极快进位计算逻辑的方法,因此有效时差并不重要。他们有很大的动力这样做,因为计算机的大部分功能都是“添加”]。
作为样式约定,如果您认为“比较两个(机器字大小)值”,则应该使用CMP指令,因为它将您正在思考的内容传达给代码的读者。它的优势在于它不会破坏其中一个操作数,一旦你编写了足够多的代码,你最终会发现这是一个非常有说服力的论据,可以使用它而不是XOR。 (TEST有这个很好的属性,对于检查位也很有用)。
其他x86指令更好的其他类型值的比较:浮动比较,字符串比较,向量寄存器比较等。这些指令与基本操作的时间不同,因为它们必须执行更复杂的操作(例如比较多个数据字)。