我正在寻找一种有效的方法来确定在整数中设置的最小有效位的位置,例如,对于0x0FF0,它将是4。
一个微不足道的实现是这样的:
unsigned GetLowestBitPos(unsigned value)
{
assert(value != 0); // handled separately
unsigned pos = 0;
while (!(value & 1))
{
value >>= 1;
++pos;
}
return pos;
}
有什么办法能挤出一些时间吗?
(注意: 这个问题是针对那些喜欢这些东西的人的,不是针对那些告诉我 xyz 优化是邪恶的人的。)
谢谢大家的点子! 我还学到了一些其他的东西。酷!