我见过ELF散列算法中使用的波浪号运算符,我很好奇它是做什么的。(代码为from Eternally Confused。)
unsigned elf_hash ( void *key, int len )
{
unsigned char *p = key;
unsigned h = 0, g;
int i;
for ( i = 0; i < len; i++ ) {
h = ( h << 4 ) + p[i];
g = h & 0xf0000000L;
if ( g != 0 )
h ^= g >> 24;
h &= ~g;
}
return h;
}
发布于 2011-08-26 23:54:28
~
运算符是按位NOT的,它反转二进制数中的位:
NOT 011100
= 100011
发布于 2011-08-26 23:54:25
~
是按位NOT运算符。它反转操作数的位。
例如,如果您有:
char b = 0xF0; /* Bits are 11110000 */
char c = ~b; /* Bits are 00001111 */
发布于 2011-08-26 23:54:27
这是按位NOT运算符。它翻转一个数字中的所有位: 100110 -> 011001
https://stackoverflow.com/questions/7207391
复制相似问题