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

詳解C語言位域的使用與注意事項

 更新時間:2016年12月20日 11:32:47   作者:zhenhuaqin  
所謂“位域”是把一個字節(jié)中的二進位劃分為幾個不同的區(qū)域, 并說明每個區(qū)域的位數(shù)。每個域有一個域名,允許在程序中按域名進行操作。 這樣就可以把幾個不同的對象用一個字節(jié)的二進制位域來表示。下面這篇文章就給大家介紹下關(guān)于C語言中位域的使用與注意事項。

位域的定義

有些信息在存儲時,并不需要占用一個完整的字節(jié), 而只需占幾個或一個二進制位。例如在存放一個開關(guān)量時,只有0和1 兩種狀態(tài), 用一位二進位即可。為了節(jié)省存儲空間,并使處理簡便,C語言又提供了一種數(shù)據(jù)結(jié)構(gòu),稱為“位域”或“位段”。所謂“位域”是把一個字節(jié)中的二進位劃分為幾個不同的區(qū)域,并說明每個區(qū)域的位數(shù)。每個域有一個域名,允許在程序中按域名進行操作。 這樣就可以把幾 個不同的對象用一個字節(jié)的二進制位域來表示。

位域的定義和位域變量的說明位域定義與結(jié)構(gòu)定義相仿,其形式為:

struct 位域結(jié)構(gòu)名
  { 位域列表 };
eg:struct weiyu {
         int a:2;
         int b:5;
         int  :5;//此五位為空域,不能使用    
         int c:3;
          }

位域雖然簡單好用,但使用時需要注意:

     1) 如果相鄰位域字段的類型相同,且其位寬之和小于類型的sizeof大小,則后面的字段將緊鄰前一個字段存儲,直到不能容納為止;

     2) 如果相鄰位域字段的類型相同,但其位寬之和大于類型的sizeof大小,則后面的字段將從新的存儲單元開始,其偏移量為其類型大小的整數(shù)倍;

     3) 整個結(jié)構(gòu)體的總大小為最寬基本類型成員大小的整數(shù)倍。

     4) 如果相鄰的位域字段的類型不同,則各編譯器的具體實現(xiàn)有差異,VC6采取不壓縮方式,Dev-C++采取壓縮方式;

     5) 如果位域字段之間穿插著非位域字段,則不進行壓縮;(不針對所有的編譯器)

注意:4 ,5跟編譯器有較大的關(guān)系,使用時要慎重,盡量避免。

#include "stdio.h"
void main(int argn ,char *argv)
{
  struct   test {
    unsigned a:10;
    unsigned b:10;
    unsigned c:6;
    unsigned :2;//this two bytes can't use
    unsigned d:4;
    }data,*pData;
  data.a=0x177;
  data.b=0x111;
  data.c=0x7;
  data.d=0x8;
  
  pData=&data;
  printf("data.a=%x data.b= %x data.c=%x data.d=%xn",pData->a,pData->b,pData->c,pData->d);//位域可以使用指針
  printf("sizeof(data)=%dn",sizeof(data));  //4 bytes ,最常用的情況
  struct testLen{
  char a:5;
  char b:5;
  char c:5;
  char d:5;
  char e:5;
  }len;
  
  printf("sizeof(len)=%dn",sizeof(len));   //5bytes 規(guī)則2
  struct testLen1{
    char a:5;
    char b:2;
    char d:3;
    char c:2;
    char e:7;
    }len1;
  printf("sizeof(len1) =%dn",sizeof(len1));  //3bytes 規(guī)則1
  struct testLen2{
    char a:2;
    char :3;
    char b:7;
    long d:20; //4bytes
    char e:4;
    }len2;
  printf("sizeof(len2)=%dn",sizeof(len2)); //12 規(guī)則3,4,5,總長為4的整數(shù)倍,2+3 占1byte,b占1bye 由于與long對其,2+3+7 占4字節(jié),后面 d 與 e進行了優(yōu)化 占一個4字節(jié)
  struct testLen3{
    char a:2;
    char :3;
    char b:7;
    long d:30;
    char e:4;
    }len3;
  printf("sizeof(len3)=%dn",sizeof(len3));//12 規(guī)則3,4,5,總長為4的整數(shù)倍,2+3 占1byte,b占1bye 由于與long對其,2+3+7 占4字節(jié),后面 d占一個4字節(jié),為了保證與long對其e獨占一個4字節(jié)
}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家學(xué)習(xí)或者使用C語言能帶來一定的幫助,如果有疑問大家可以留言交流。

相關(guān)文章

  • C++實現(xiàn)五子棋游戲

    C++實現(xiàn)五子棋游戲

    這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • JS調(diào)用C++函數(shù)拋出異常及捕捉異常詳解

    JS調(diào)用C++函數(shù)拋出異常及捕捉異常詳解

    這篇文章主要介紹了js調(diào)用C++函數(shù)的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-08-08
  • 詳解C++?轉(zhuǎn)換的非正式分類

    詳解C++?轉(zhuǎn)換的非正式分類

    C++?正式分類方法是直接按語法分類,分為:隱式轉(zhuǎn)換和顯示轉(zhuǎn)換。這篇文章主要介紹了C++?轉(zhuǎn)換的非正式分類,需要的朋友可以參考下
    2022-01-01
  • C++ 中的 if-constexpr語法和作用

    C++ 中的 if-constexpr語法和作用

    ?if-constexpr語法是 C++ 17 引入的新語法特性,也被稱為常量 if 表達式或靜態(tài) if(static if),這篇文章主要介紹了C++ 中的 if-constexpr語法和作用,需要的朋友可以參考下
    2025-03-03
  • C++運算符重載圖文詳解

    C++運算符重載圖文詳解

    運算符重載的方法是定義一個重載運算符的函數(shù),在需要執(zhí)行被重載的運算符時,系統(tǒng)就自動調(diào)用該函數(shù),以實現(xiàn)相應(yīng)的運算。也就是說,運算符重載是通過定義函數(shù)實現(xiàn)的
    2021-09-09
  • C++中動態(tài)綁定和內(nèi)存管理的實現(xiàn)

    C++中動態(tài)綁定和內(nèi)存管理的實現(xiàn)

    本文主要介紹了C++中動態(tài)綁定和內(nèi)存管理的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-12-12
  • C++實現(xiàn)LeetCode(141.單鏈表中的環(huán))

    C++實現(xiàn)LeetCode(141.單鏈表中的環(huán))

    這篇文章主要介紹了C++實現(xiàn)LeetCode(141.單鏈表中的環(huán)),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語言 makefile學(xué)習(xí)及實現(xiàn)實例

    C語言 makefile學(xué)習(xí)及實現(xiàn)實例

    這篇文章主要介紹了C語言 makefile學(xué)習(xí)及實現(xiàn)實例的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • C++自動析構(gòu)時的順序問題

    C++自動析構(gòu)時的順序問題

    這篇文章主要介紹了C++自動析構(gòu)時的順序,通過實例代碼給大家講解了C++ 構(gòu)造與析構(gòu)的執(zhí)行順序,代碼簡單易懂,非常不錯對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • C++實現(xiàn)旋轉(zhuǎn)數(shù)組的二分查找

    C++實現(xiàn)旋轉(zhuǎn)數(shù)組的二分查找

    這篇文章主要介紹了C++實現(xiàn)旋轉(zhuǎn)數(shù)組的二分查找方法,涉及數(shù)組的操作,有值得借鑒的技巧,需要的朋友可以參考下
    2014-09-09

最新評論