位掩码左移

时间:2015-12-04 00:30:10

标签: c bit-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;
}

1 个答案:

答案 0 :(得分:8)

更好

#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。