C中的Bit Hack无法理解

Mat*_*gan 3 c bit-manipulation

我在接受采访时被问到这个问题,但仍无法弄清楚它的作用.有人可以解释它的作用以及它是如何做到的吗?

v = v - ((v >> 1) & (T)~(T)0/3);                           // temp
v = (v & (T)~(T)0/15*3) + ((v >> 2) & (T)~(T)0/15*3);      // temp
v = (v + (v >> 4)) & (T)~(T)0/255*15;                      // temp
c = (T)(v * ((T)~(T)0/255)) >> (sizeof(T) - 1) * CHAR_BIT; // count
Run Code Online (Sandbox Code Playgroud)

oua*_*uah 10

这里解释如下:

http://graphics.stanford.edu/~seander/bithacks.html#CountBitsSetParallel

计数位并行设置

将最佳位计数方法推广到位宽高达128的整数(由类型T参数化)是这样的:

v = v - ((v >> 1) & (T)~(T)0/3);                           // temp
v = (v & (T)~(T)0/15*3) + ((v >> 2) & (T)~(T)0/15*3);      // temp
v = (v + (v >> 4)) & (T)~(T)0/255*15;                      // temp
c = (T)(v * ((T)~(T)0/255)) >> (sizeof(T) - 1) * CHAR_BIT; // count
Run Code Online (Sandbox Code Playgroud)

  • @templatetypedef这个页面是C bit hacks的页面,所以我去检查它是否已经在这里. (2认同)