在C中进行谓词赋值的更好方法是什么?

时间:2012-09-26 23:35:43

标签: c

我要做的是避免以下情况:

if(*ptr > 128) {
   number = 5;
}

当没有关于分支将走哪条路的明确模式时,这样的代码表现不佳。我想出的是:

int arr[] = { number, 5 };
int cond = *ptr > 128;
number = arr[cond];

根据我的测试,当输入是随机的时,其运行速度是条件的两倍。我想知道的是,是否有更聪明的方法来做到这一点,也许使用按位运算符。

1 个答案:

答案 0 :(得分:5)

一个聪明的编译器肯定应该使用正确的优化设置将其编译为条件移动;检查拆卸是否确定。

有这种无分支解决方案:

int mask = -(*ptr > 128);
number = (number & mask) | (5 & ~mask);

最后一行也可以是

number = ((mask & (number ^ 5)) ^ 5);

如果您希望少用一次操作。但是, caveat emptor ,编译器将无法优化其中任何一个。除非您特别知道编译器无法进行优化(在这种情况下,您可能需要检查编译器版本或标志),否则最好将此特定优化留给编译器担心。