版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、第十三章 位運算,,學習目標,位運算的有關概念和運算規(guī)律位段的概念,課程內(nèi)容,13.1 概述13.2 位運算符和位運算13.3位段,13.1 概述,C語言程序設計最大的一個特點就是可以對計算機硬件進行操作,其操作主要是通過位運算實現(xiàn)的。位運算很適合編寫系統(tǒng)軟件的需要,是C語言的重要特色。在計算機用于檢測和控制領域中要用到位運算的知識。所謂位運算就是指進行二進制的運算。在系統(tǒng)軟件中,常要處理二進制的問題。例如,將一個存儲單元
2、中的各二進制左移或者右移一位,兩個數(shù)按位相加等。C語言提供位運算的功能,與其他高級語言相比,顯然具有很大的優(yōu)越性。,C語言提供6種位運算符,說明:(1)"~"為單目運算符,其余均為雙目運算符,優(yōu)先級高低順序: 按位求反~ 移位 按位與& 按位異或^ 按位或|(2)運算量只能是整型或字符型數(shù)據(jù),浮點數(shù)不能參與運算 (3)參與運算時,操作數(shù)都
3、必須轉(zhuǎn)換成二進制形式,然后再執(zhí)行按位運算,13.2 位運算符和位運算,如果左移出的位不是1,則左移操作相當于乘法操作,左移一位相當于原數(shù)乘以2,左移n位,則相當于原數(shù)乘以2n,左移位運算符 <<格式:x<<位數(shù)規(guī)則:使操作數(shù)的各位左移,低位補0,高位溢出。例:5<<2= 20,右移位運算符 >>格式:x>>位數(shù)規(guī)則:使操作數(shù)的各位右移,移出的低位舍棄,高位補符號
4、位。例:20 >>2= 5,左移操作相當于除法操作,右移一位相當于原數(shù)除以2,右移n位,則相當于原數(shù)除以2n,【例13.1】左移位1 #include 2 void main()3 {4 int a=-1;5 int i=0;6 for (i=0; i<17; i++)7 {8printf("%d<<%d=%d\t", a, i, a&l
5、t;<i);9printf("0x%x<<%d=0x%x\n", a, i, a<<i);10 }11 },運行結果如下:-1<<0=-10xffff<<0=0xffff-1<<1=-20xffff<<1=0xfffe-1<<2=-40xffff<<2=0xfffc-1<<3=
6、-80xffff<<3=0xfff8-1<<4=-160xffff<<4=0xfff0-1<<5=-320xffff<<5=0xffe0-1<<6=-640xffff<<6=0xffc0-1<<7=-1280xffff<<7=0xff80-1<<8=-2560xffff<<8=0xff
7、00-1<<9=-5120xffff<<9=0xfe00-1<<10=-1024 0xffff<<10=0xfc00-1<<11=-20480xffff<<11=0xf800-1<<12=-40960xffff<<12=0xf000-1<<13=-81920xffff<<13=0xe000-1&
8、lt;<14=-16384 0xffff<<14=0xc000-1<<15=-32768 0xffff<<15=0x8000-1<<16=0 0xffff<<16=0x0,整型數(shù)據(jù)是采用補碼表示的。每左移一位相當于數(shù)據(jù)乘以2,當移位結果超出數(shù)據(jù)表示范圍時,結果就不再正確。,【例13.2】右移位1 #include 2 void main()3 {4
9、 int a=0xc57f;5 int i;6 for (i=0; i>%d=%d\t", a, i, a>>i);9printf("0x%x>>%d=0x%x\n", a, i, a>>i);10 }11 },運行結果如下:-14977>>0=-14977 0xc57f>>0=0xc57f-1497
10、7>>1=-7489 0xc57f>>1=0xe2bf-14977>>2=-3745 0xc57f>>2=0xf15f-14977>>3=-1873 0xc57f>>3=0xf8af-14977>>4=-937 0xc57f>>4=0xfc57-14977>>5=-469 0xc57f>>5=
11、0xfe2b-14977>>6=-235 0xc57f>>6=0xff15-14977>>7=-118 0xc57f>>7=0xff8a-14977>>8=-59 0xc57f>>8=0xffc5-14977>>9=-30 0xc57f>>9=0xffe2-14977>>10=-15
12、 0xc57f>>10=0xfff1-14977>>11=-8 0xc57f>>11=0xfff8-14977>>12=-4 0xc57f>>12=0xfffc-14977>>13=-2 0xc57f>>13=0xfffe-14977>>14=-1 0xc57f>>14=0xffff
13、-14977>>15=-1 0xc57f>>15=0xffff,整數(shù)-14977的補碼是0xc57f。整型數(shù)據(jù)每右移一位相當于數(shù)據(jù)除以2,同時還注意到-1/2=-1。,其他位運算 除了移位運算,二進制數(shù)據(jù)的位運算還包括與、或、非、異或四種類型。 從數(shù)據(jù)本身的角度來看,位運算本身的意義不大。但是在跟計算機硬件相關的很多操作中,位運算有其他運算無可比擬的優(yōu)勢。,位運算真值表,【例13.3】
14、將數(shù)據(jù)的最末位置位為0。 1 #include 2 void main()3 {4 int aValue;5 int i;6 for (i=0; i<5; i++)7 {8 printf("Please input a integer:");9 scanf("%d", &aValue)
15、;10 aValue=aValue&0xfffe;11 printf("The new value is:%d\n", aValue);12 }13 },運行結果如下:Please input a integer:19↙The new value is:18Please input a integer:1221↙The new value is:1220
16、Please input a integer:12↙The new value is:12Please input a integer:17↙The new value is:16Please input a integer:400↙The new value is:400,【例13.4】字符串的簡單加密1#include 2#include 3void main()4{5char maskChar=0
17、x55;6char *sourceString="Hello";7char *destString1;8char *destString2;9int i;10destString1=malloc(strlen(sourceString));11destString2=malloc(strlen(sourceString));12for (i=0; i<strlen(so
18、urceString); i++)13destString1[i]=sourceString[i]^maskChar;14destString1[i]='\0';15for (i=0; i<strlen(sourceString); i++)16destString2[i]=destString1[i]^maskChar;17destString2[i]='\0';
19、18printf("sourceString=%s\n", sourceString);19printf("destString1=%s\n", destString1);20printf("destString2=%s\n", destString2);21},運行結果如下:sourceString=HellodestString1=?099:de
20、stString2=Hello,【例13.5】AD574是一種A/D轉(zhuǎn)換器,它的作用就是將模擬信號轉(zhuǎn)換成數(shù)字信號。它對外有2個端口,分別叫作偶地址端口和奇地址端口。向偶地址端口發(fā)送命令可以啟動A/D轉(zhuǎn)換,從偶地址端口讀取數(shù)據(jù)可以獲取A/D轉(zhuǎn)換是否完成的狀態(tài)。在A/D完成后,從偶地址可以獲取轉(zhuǎn)換數(shù)據(jù)的高8位數(shù)據(jù),從奇地址可以獲取低4位數(shù)據(jù)。假設根據(jù)硬件連接情況,得到端口地址0x500和0x501。在C語言的庫函數(shù)中,有訪問外設端口的out
21、portb函數(shù),它將一個字節(jié)數(shù)據(jù)寫入外設端口寄存器。inportb函數(shù)把端口寄存器中一個字節(jié)讀入CPU。下面的程序給出了一個數(shù)據(jù)采集函數(shù)。1unsigned ad_convert ()2{3unsigned ad_h8 = 0 ;4unsigned ad_L4 = 0 ;5unsigned ad_result = 0;6outportb(0x500 ,0xff);7while (inport
22、b(0x500) &&0x80);8ad_h8 = (unsigned) inportb(0x500) ;9ad_L4 = (unsigned) inportb(0x501) ;10ad_h8 = ad_h8>4 ;12ad_result = ad_h8 + ad_L4 ;13return(ad_result) ;14},13.3 位段,我們知道計算機中信息的存儲一般是以字節(jié)為單位
23、的。實際上,有時一個信息本身可能用不到那么多位。例如,要表示人的性別只需1位二進制數(shù)據(jù)就可以,譬如0代表“男”,1代表“女”。再例如在過程控制領域,一個字節(jié)的數(shù)據(jù)可以表示多個命令或者設備的多個狀態(tài)特征。雖然可以用移位或其他位運算組合成我們需要的信息,但是,C語言提供了更方便的利用位段結構處理信息的方法。,位段:在一個結構體中可以以位為單位來指定 其成員所占內(nèi)存長度,這種以位為單位 的成員
24、稱為位段(或位域)。,如:struct packed_data { unsigned a : 2; unsigned b : 3; unsigned c : 4; int i; }data;,位段的引用:,結構體變量名. 位段成員名,如:struct packed_data { unsigned a : 2;
25、 unsigned b : 3; unsigned c : 4; int i; }data;,位段的引用如下: data.a=2; data.b=7; data.c=9;,【例13.6】定義位段1typedef struct2{3unsigned a:3;4unsigned b:1;5unsi
26、gned c:7;6}Some_bits;7#include 8void main()9{10Some_bits theseBits;11unsigned int *pInteger;12pInteger=(unsigned int *)&theseBits;13*pInteger=0;14theseBits.a=6;15theseBits.b=1;16theseBits
27、.c=16;17printf("sizeof(Some_bits)=%d\n",sizeof(Some_bits));18printf("*pInteger=%x\n",*pInteger);19printf("%u,%u,%u\n",theseBits.a, theseBits.b, theseBits.c);20},,位段的定義,位段的賦值,位段的引用
28、,運行結果如下:sizeof(Some_bits)=2*pInteger=10e6,1,16,有定義的位段位于整個結構數(shù)據(jù)的低位。,,在位段中定義無名字段含義:跳過該字節(jié)剩余的位或指定的位不用。 當無名字長度為0時,跳過該字節(jié)剩余的位不用;當無名字段長度為n時,跳過n位不用。,如:struct packed_data { unsigned a : 2; unsigne
29、d b : 3; unsigned : 0; unsigned c : 4; int i; }data;,【例13.7】未命名位段舉例。1typedef struct2{3unsigned a:3;4unsigned :2;5unsigned b:1;6unsigned :0;7unsigned c:7;8
30、}Unamed_bits;9#include 10void main()11{12Unamed_bits theseBits;13unsigned int *pInteger;14pInteger=(unsigned int *)&theseBits;15*pInteger=0;16theseBits.a=6;17theseBits.b=1;18theseBits.c=16
31、;19printf("sizeof(Unamed_bits)=%d\n", sizeof(Unamed_bits));20printf("*pInteger=%x\n", *pInteger);21printf("%u,%u,%u\n", theseBits.a, theseBits.b, theseBits.c);22},運行結果如下:sizeof(U
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論