欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一篇帶你了解C語言--位操作詳情

 更新時間:2021年08月12日 17:27:39   作者:Sauron7i  
這篇文章主要介紹了關于C語言位運算的簡單示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

在C語言中,是可以單獨操控變量中的位的。因為C在提供高級語言便利的同時,還能在為匯編語言所保留的級別上工作。

二進制數(shù)、位和字節(jié)

在我們日常生活中通常使用的十進制。

例如數(shù)字1234可以寫成:

1 *10e3 + 2 * 10e2 + 3 * 10e1 + 4 * 10e0

這種方法是基于10的冪,所以稱為以10為基底書寫的。

那么以2為基底表示的數(shù)字就是二進制數(shù)。

例如:二進制數(shù)1111

1 * 2e3 + 1 * 2e2 + 1 * 2e1 + 1 * 2

轉換成十進制就是:

1* 8+1* 4+1*2+1 = 15

二進制整數(shù)

C語言用字節(jié)表示存儲系統(tǒng)字符集所需的大小,通常1字節(jié)為8位。

可以從左往右給這8位分別編號 7~0。在一字節(jié)中,編號是7的位被稱為高階位,編號為0的被稱為低階位,每一位的編號對應2的相應指數(shù)。

在這里插入圖片描述

該字節(jié)能表示的最大的數(shù)字是把所有位設置為1:1111 1111,其值為255。最小值就是:0000 0000,其值為0。

所以1字節(jié)可以存儲0~255范圍內的數(shù)字總共256個值,在ASCII碼中對應了256個狀態(tài)。

unsigned char用1字節(jié)表示的范圍是0~255,而signed char 用1字節(jié)表示范圍是-128 ~ 127。

有符號整數(shù)

表示有符號數(shù)最簡單的方式是用1位(高階位)存儲符號,剩下7位表示數(shù)字。
用這種符號量表示法,1000 0001表示 -1、0000 0001表示 1。其表示范圍是 -127~127。這種方法的缺點是有兩個0,+0和-0,有點浪費。

二進制補碼方法避免了這個問題。以一字節(jié)為例:
二進制補碼用1字節(jié)中的后7位表示0~127,高階位設置為0.如果高階位是1,表示的是負數(shù)。 假設一個值位組合為:1000 0000,無符號字節(jié)就表示的128,有符號字節(jié)表示-128。

要得到一個二進制補碼的數(shù)的相反數(shù),最簡單的方法是反轉每一位,然后加1。
1是0000 0001,-1就是 1111 1110 + 1,或 1111 1111。

二進制浮點數(shù)介紹

一個普通的十進制浮點數(shù)可以這樣表示

0.234 = 2 /10 + 3 / 100 + 4 / 1000

從左往右各分母都是10的遞增次冪。

那么在二進制浮點數(shù)中,使用2的冪作為分母,比如

.1011 = 1 / 2 + 0 / 4 + 1 / 8 + 1 / 16

八進制和十六進制

八進制以8為基底,用0~7表示數(shù)字。十六進制以16作為基底,用0 ~15表示數(shù)字。但沒有單獨的數(shù)表示10 ~ 15,所以用字母 A ~F表示。

在這里插入圖片描述

3位二進制對應一位八進制

4位二進制對應一位十六進制

C按位運算符

C提供了按位邏輯運算符和移位運算符。

按位邏輯運算符

4個按位邏輯運算符都用于整形數(shù)據(jù),包括char。

二進制反碼或按位取反:~

一元運算符把1變?yōu)?,把0變?yōu)?。示例:

~(0001 1100)	//表達式
 (1110 0011)	// 結果值

需要注意的是該運算符不會改變之前變量的值,但確實創(chuàng)建了一個可以使用或賦值的新值。

按位與:&

二元運算符通過逐位比較兩個運算對象生成一個新值。
對于每一個位,兩個運算對象中相應的位都為1時,結果為1。示例:

(1001 1001) & (0011 1100)
//結果為
(0001 1000)

C有按位與和賦值結合的運算符:&=

val &= 0247
等價于
val = val & 0247

按位或:|

二元運算符|,對于每個位,如果兩個運算對象中相應的位是1,結果為1。
示例:

(1001 1001) | (0111 0010)
結果為
(1111 1011)

同時C也有這樣的運算符:|=

按位異或:^

二元運算符 ^,對于每一位,如果兩個運算對象中相應的位一個為1,但不是兩個為1,結果為1。
示例:

(1100 0001) ^ (0101 1011)
結果為
(1001 1010)

同時C也有這樣的運算符: ^=

用法:掩碼

所謂掩碼指的是一些設置為開(1)或關(0)的位組合。
假設定義符號常量MASK為2,即(0000 0010),那么語句

val &= MASK

就是把val中除了1號位以外的所有位都設置為01號位的值不變。這個過程叫做使用掩碼,掩碼中的0隱藏了val中的其他位。
圖解:

在這里插入圖片描述

用法:打開位(設置位)

有時需要打開一個值中的特定位,而其他位保持不變。

val |= MASK;

把val的1號位設置為1,其他位不變。

因為|運算符,任何位與0組合結果為本身,任何位與1組合,結果都為1。

用法:關閉位(清空位)

和打開類似,有時需要再不影響其他位的情況下關閉指定的位。
假設要關閉變量val中的1號位,MASK只有1號位為1。即:

val = val & ~MASK;

由于MASK除1號位以外全為0,那~MASK除1號位以外全為1。再使用&,任何位與1組合都為本身,所以這條語句保持除1號位以外其他各位不變。
示例:

val ^= MASK;
(0000 1111) ^ (1011 0110)
結果為
(10111001)

用法:切換位

是指打開已關閉的位,或關閉已打開的位??梢允褂冒次划惢蜻\算符(^)切換位。

if ((val & MASK) == MASK)
	printf("...");

val中與MASK為1的位相對應的位都被切換了,MASK為0的位相對應的位不變。

用法:檢查位的值

若檢查val的某一位是否為1,可設置一個掩碼剛好這個位為1.

若檢查第二位,即:

MASK為(0000 0010)

程序可以這樣寫:

if ((val & MASK) == MASK)
	printf("...");

為了避免信息漏過邊界,掩碼至少要與其覆蓋的值寬度相同。

移位運算符

左移:<<

左移運算符將其左側運算對象每一位的值向左移動其右側運算對象指定的位數(shù)。左側運算對象移出左末端位的值丟失,用0填充空出的位置。
示例:

(1000 0110) << 2
結果為
(0001 1000)

可以使用左移賦值運算符(<<=)來更改變量的值。

int val = 1;	//0000 0001
val <<= 2;
結果為
0000 0100

右移:>>

右移運算符將其左側運算對象每一位的值向右移動其右側運算對象指定的位數(shù)。

對于無符號類型,用0填充空出的位置,對于有符號類型,結果取決于機器。

示例:>>=

int val = 16;	//0001 0000
val >>= 3;
結果為:
0000 0010

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

您可能感興趣的文章:

相關文章

  • 如何通過UltraEdit解析BMP文件內部結構(BMP位圖基礎)

    如何通過UltraEdit解析BMP文件內部結構(BMP位圖基礎)

    我們先打開畫圖隨便畫一幅圖并采用24位bmp圖像格式保存,就得到了一張24位真彩色的位圖,下面我們來詳細分析bmp位圖的各個組成部分,感興趣的朋友跟隨小編一起看看吧
    2021-08-08
  • C++實現(xiàn)停車場管理系統(tǒng)的示例代碼

    C++實現(xiàn)停車場管理系統(tǒng)的示例代碼

    停車場管理系統(tǒng)就是模擬停車場進行車輛管理的系統(tǒng),該系統(tǒng)分為汽車信息模塊,用戶使用模塊和管理員用戶模塊,本文將用C++實現(xiàn)這一簡單的系統(tǒng),希望對大家有所幫助
    2023-04-04
  • win32使用openfilename瀏覽文件窗口示例

    win32使用openfilename瀏覽文件窗口示例

    這篇文章主要介紹了使用win32 API打開瀏覽文件窗口,使用OPENFILENAME結構體來實現(xiàn)這個功能,需要的朋友可以參考下
    2014-02-02
  • C++中最常用的容器用法與排序實例

    C++中最常用的容器用法與排序實例

    C++ 中容器被定義為:在數(shù)據(jù)存儲上,有一種對象類型,它可以持有其它對象或指向其它對像的指針,這種對象類型就叫做容器,這篇文章主要給大家介紹了關于C++中最常用的容器用法與排序的相關資料,需要的朋友可以參考下
    2021-08-08
  • C++11 并發(fā)指南之std::thread 詳解

    C++11 并發(fā)指南之std::thread 詳解

    這篇文章主要介紹了C++11 并發(fā)指南之std::thread 詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • C語言修煉之路初識分支句?循環(huán)助本心上篇

    C語言修煉之路初識分支句?循環(huán)助本心上篇

    現(xiàn)實生活中我們經(jīng)常需要根據(jù)不同的條件做出不同的選擇。程序設計中也需要根據(jù)條件來選擇不同的程序進行處理,這稱之為分支結構,當條件表達式不存在時,它被假設為真。您也可以設置一個初始值和增量表達式,一般情況下,C?程序員偏向于使用?for(;;)?結構來表示一個無限循環(huán)
    2022-03-03
  • C語言鏈表實現(xiàn)貪吃蛇游戲

    C語言鏈表實現(xiàn)貪吃蛇游戲

    這篇文章主要為大家詳細介紹了C語言鏈表實現(xiàn)貪吃蛇游戲源碼,適合C語言入門者學習閱讀,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • 帶頭結點的鏈表的基本操作(超詳細)

    帶頭結點的鏈表的基本操作(超詳細)

    鏈表是一種動態(tài)分配空間的存儲結構,能更有效地利用存儲空間,通過對單鏈表基本操作的代碼實現(xiàn),我深刻領悟到以“指針”指示元素的后繼,在插入或刪除元素時不需要移動元素
    2023-07-07
  • C語言實現(xiàn)井字棋詳解

    C語言實現(xiàn)井字棋詳解

    這篇文章主要為大家介紹了C語言如何實現(xiàn)井字棋,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • C語言實現(xiàn)支持動態(tài)拓展和銷毀的線程池

    C語言實現(xiàn)支持動態(tài)拓展和銷毀的線程池

    這篇文章主要為大家介紹了C語言實現(xiàn)支持動態(tài)拓展和銷毀的線程池,感興趣的小伙伴們可以參考一下
    2016-01-01

最新評論