位掩码左移
bit mask left shift
我试图解决一个问题,但我不知道它是否是好的解决方案。
构建一个 unsigned long 类型的掩码,将 14 个最低有效位(从右边开始)设置为 1;
#include <stdio.h>
#include <stdlib.h>
unsigned long mask;
int main()
{
int i;
for(i=0;i<14;i++)
mask|=(1<<i);
printf("%li",mask);
return 0;
}
比较好
#include <stdio.h>
#include <stdlib.h>
unsigned long mask;
int main()
{
int num = 14;
mask = (1 << num) - 1;
printf("%lu", mask);
return 0;
}
这里num
是最低有效位的总数。
工作原理
2^14 = 16348 的二进制表示是 0000000000000000 0100000000000000
(32 位)
2^14-1 = 16347 的二进制表示是 0000000000000000 0011111111111111
所以 14 个最低有效位设置为 1。
我试图解决一个问题,但我不知道它是否是好的解决方案。
构建一个 unsigned long 类型的掩码,将 14 个最低有效位(从右边开始)设置为 1;
#include <stdio.h>
#include <stdlib.h>
unsigned long mask;
int main()
{
int i;
for(i=0;i<14;i++)
mask|=(1<<i);
printf("%li",mask);
return 0;
}
比较好
#include <stdio.h>
#include <stdlib.h>
unsigned long mask;
int main()
{
int num = 14;
mask = (1 << num) - 1;
printf("%lu", mask);
return 0;
}
这里num
是最低有效位的总数。
工作原理
2^14 = 16348 的二进制表示是 0000000000000000 0100000000000000
(32 位)
2^14-1 = 16347 的二进制表示是 0000000000000000 0011111111111111
所以 14 个最低有效位设置为 1。