例 12.1取一个整数a从右端开始的4~7位。
可以这样考虑:
① 先使a右移4位。见图12.3。图12.3(a)是未右移时的情况,(b)图是右移4位后的情况。目的是使要取出的那几位移到最右端。
右移到右端可以用下面方法实现:
a >> 4
② 设置一个低4位全为1,其余全为0的数。可用下面方法实现:
~ ( ~ 0 << 4 )
~0的全部二进制为全1,左移4位,这样右端低4位为0。见下面所示:
0:0000…000000
~0,1111…111111
~0<<4:1111…110000
~(~0<<4):0000…001111
③ 将上面二者进行&运算。即
(a >> 4) & ~ ( ~ 0 << 4 )
根据上一节介绍的方法,与低4位为1的数进行&运算,就能将这4位保留下来。
程序如下:
main( )
{unsigned a,b,c,d;
scanf("%o",&a);
b=a>>4;
c=~(~0<<4);
d=b&c;
printf("%o,%d\n%o,%d\n",a,a,d,d);
}
运行情况如下:
331
  331,217(a的值)
15,13 (d的值)
输入a的值为八进制数331,即十进制数217,其二进制形式为11011001。经运算最后得到的d为00001101,即八进制数15,十进制数13。
可以任意指定从右面第m位开始取其右面n位。只需将程序中的“b=a>>4”改成“b=a>>(m-n+1)”以及将“c=~(~0<<4)”改成“c=~(~0<<n)”即可。