C语言 位移运算符的使用
<< 運(yùn)算符 和 >> 運(yùn)算符的作用是求出將整數(shù)中的所有位左移或右移之后生成的值。
| << 運(yùn)算符 | a << b | 將 a 左移 b 位。右面空出的位用0填充 |
| >>運(yùn)算符 | a >>b | 將a右移b位 |
注:這些運(yùn)算符的操作數(shù)必須是整數(shù)類數(shù)據(jù)類型或枚舉型
#include <stdio.h>int count_bits(unsigned x){int count = 0;while(x) {if (x & 1U) {count++;}x >>= 1;}return count; }int int_bits(void){return count_bits(~0U); }void print_bits(unsigned x){int i ;for (i = int_bits() - 1; i >= 0; i--){putchar(((x >> i) & 1U) ? '1' : '0');} }int main(void){unsigned num1, n;printf("非負(fù)整數(shù):");scanf("%u", &num1);printf("位移位數(shù):");scanf("%u", &n);printf("\n整數(shù)轉(zhuǎn)換為2進(jìn)制 = ");print_bits(num1);printf("\n整數(shù)左移后的值 = ");print_bits(num1 << n);printf("\n整數(shù)右移后的值 = ");print_bits(num1 >> n);putchar('\n');return 0; }運(yùn)行結(jié)果:
- count_bits函數(shù):功能是計(jì)算形參 x 所接收到的無符號(hào)整數(shù)中有多少個(gè)值為1的二進(jìn)制位,并返回其個(gè)數(shù)。
1U(只有低位為1的無符號(hào)整數(shù))和x的邏輯與運(yùn)算,判斷x的低位是否為1。如果低位為1,則bits遞增。 - int_bits函數(shù):返回int型和unsigned型的位數(shù)。
~0U是所有位都為 1 的unsigned 型整數(shù)(將所有位都為0的無符號(hào)整數(shù)0U的所有位反轉(zhuǎn)得到)。 - print_bits函數(shù): 將unsigned型整數(shù)的高位到地位的所有位都用1 和 0來顯示的函數(shù)。
函數(shù) print_bits 是將無符號(hào)整數(shù) x 的所有位有用 0 和 1 來表示的函數(shù)。函數(shù) int_bits 和 count_bits 被用于執(zhí)行這一工作。
總結(jié):
使用 << 運(yùn)算符進(jìn)行左移
表達(dá)式 x << n 會(huì)將x的所有位左移 n 位,并在右邊空出的位(低位)上補(bǔ)0。二進(jìn)制的每一位都是2的指數(shù)冪,所以左移 1 位后,只要沒有發(fā)生數(shù)據(jù)溢出,值就會(huì)變?yōu)樵瓉淼?倍。
使用 >> 運(yùn)算符進(jìn)行右移
表達(dá)式 x >> n 會(huì)將x的所有位右移n位。二進(jìn)制數(shù)右移 1 位后,值會(huì)變?yōu)樵瓉淼亩种弧?/p>
當(dāng) x 時(shí)有符號(hào)整型的復(fù)數(shù)是,位移運(yùn)算的結(jié)果因編譯器而異。在許多編譯器中,會(huì)執(zhí)行邏輯位移或算術(shù)位移。
注:雖然可以對(duì)負(fù)數(shù)進(jìn)行位移,對(duì)一個(gè)數(shù)做負(fù)數(shù)位移位的操作是不規(guī)范的,所以最好不要對(duì)負(fù)數(shù)進(jìn)行位移。
總結(jié)
以上是生活随笔為你收集整理的C语言 位移运算符的使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言 用代码将10进制转换为2进制表示
- 下一篇: C语言 整型变量的输入和输出