• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            程序讓生活更美好

            半畝方塘 天光云影

              C++博客 ::  :: 新隨筆 :: 聯系 ::  :: 管理 ::
              55 隨筆 :: 4 文章 :: 202 評論 :: 0 Trackbacks

            struct union 的區別

            在編程的時候,經常會遇到使用一個變量處理多種數據的情況,在這種情況下,如果我們不考慮使用類,那么就可以是struct(結構)和union(聯合)來進行處理。那么,這兩種結構之間到底有什么不同呢?

            可以先看下面的一個小例子。

             1 #include  < iostream >
             2 using   namespace  std;
             3
             4 union U1 {
             5      char  c;
             6      int  i;
             7      double  d;
             8     }
            ;
             9 union U2 {
            10      char  c;
            11      // int i;
            12      // double d;
            13     }
            ;
            14
            15 union U3 {
            16      char  c;
            17      int  i;
            18      // double d;
            19     }
            ;
            20
            21 struct  S1 {
            22      char  c;
            23      int  i;
            24      double  d;
            25     }
            ;
            26
            27 struct  S2 {
            28      char  c;
            29      int  i;
            30      // double d;
            31     }
            ;
            32
            33 int  main() {
            34     cout << " U1's size = " << sizeof (U1) << endl;
            35     cout << " U2's size = " << sizeof (U2) << endl;
            36     cout << " U3's size = " << sizeof (U3) << endl;
            37     cout << endl;
            38     cout << " -------------------------------- " << endl;
            39     cout << " S1's size = " << sizeof (S1) << endl;
            40     cout << " 其中 " << sizeof ( char ) << " + " << sizeof ( int ) << " + " << sizeof ( double ) << " = " << sizeof ( char ) + sizeof ( int ) + sizeof ( double ) << endl;
            41     cout << " ---------- " << endl;
            42     cout << " S2's size = " << sizeof (S2) << endl;
            43     cout << " 其中 " << sizeof ( char ) << " + " << sizeof ( int ) << " = " << sizeof ( char ) + sizeof ( int ) << endl;
            44     cout << " -------------------------------- " << endl;
            45     S1 s;
            46     s.c = ' A ' ;
            47         cout << " 1 s.c =  " << s.c << endl;
            48     s.d = 23.2132 ;
            49         cout << " 1 s.d =  " << s.d << endl;
            50
            51         cout << " 2 s.c =  " << s.c << endl;
            52         cout << " 2 s.d =  " << s.d << endl;
            53         cout << " -----------------------  " << endl;
            54     U1 u;
            55         u.c = ' A ' ;
            56         cout << " 1 u.c =  " << u.c << endl;
            57     
            58         u.i = 23322 ;
            59         cout << " 1 u.i =  " << u.i << endl;
            60
            61         u.d = 23.2132 ;
            62         cout << " 1 u.d =  " << u.d << endl;
            63         cout << " 2 u.c =  " << u.c << endl;
            64         cout << " 2 u.i =  " << u.i << endl;
            65      return   0 ;
            66 }

            67

            輸出結果為:

            U1's size =8

            U2's size =1

            U3's size =4

             

            --------------------------------

            S1's size =16

            其中 1+4+8=13

            ----------

            S2's size =8

            其中 1+4=5

            --------------------------------

            1 s.c = A

            1 s.d = 23.2132

            2 s.c = A

            2 s.d = 23.2132

            -----------------------

            1 u.c = A

            1 u.i = 23322

            1 u.d = 23.2132

            2 u.c =

            2 u.i = 1181975000

            解釋:

            struct 類型的內存分配是結合內部的所有變量大小和相關的,但不是簡單的相加,從上面的例子就可以看出來, struct 類型的分配的內存大小是應該內部最大數據類型的整數倍,不足一倍的部分會自動補全成一倍大小,應該是編譯器為了數據整齊,處理速度會快些把。 union 類型的內存分配,只是和聯合體內的最大的一個數據類型的大小相關,而且 union 內的所有數據都在一個單獨的內存空間里面。這些就是上面程序出現這樣的結果的原因。


               所以,
            u.c 的值是 A ,當給聯合體內的其他變量賦值之后, u.c 的值就是一個無用的信息。同樣, u.i 的值最初是 23322 ,當給 u.d 賦值 23.2132 之后, u.i 的值就變得無用了。


            posted on 2006-03-20 17:02 北風之神007 閱讀(10000) 評論(5)  編輯 收藏 引用 所屬分類: c/c++

            評論

            # re: struct 與union的區別 2007-09-07 10:47 路人甲
            謝謝~~ 學到了不少

            不過感覺struct類型的分配的內存大小應該是,大于等于內部所有變量大小的和的一個2的密指數。
              回復  更多評論
              

            # re: struct 與union的區別 2008-01-26 11:42 路人已
            真的很感謝,終于知道了union的優點了*^_^*  回復  更多評論
              

            # re: struct 與union的區別 [未登錄] 2008-11-04 15:23 tom
            memory alignment@路人甲
              回復  更多評論
              

            # re: struct 與union的區別 2010-09-21 09:08 愛的隧道
            @路人甲
            應該是不小于所有變量的和且最接近之的4的倍數。  回復  更多評論
              

            # re: struct 與union的區別 [未登錄] 2011-09-23 15:02 aaaa
            最后為什么2 u.i = 1181975000?  回復  更多評論
              

            婷婷综合久久中文字幕| 91久久精品国产成人久久| 欧美一区二区三区久久综| 久久精品国产亚洲AV高清热| 久久久久国产精品| 日韩中文久久| 国产精品久久国产精品99盘| 亚洲国产精品嫩草影院久久| AV无码久久久久不卡蜜桃| 青青青青久久精品国产h| 久久九九兔免费精品6| 99久久99久久精品国产片果冻| 久久久久波多野结衣高潮| 久久亚洲国产成人影院网站| 99精品久久精品| 中文字幕无码免费久久| 开心久久婷婷综合中文字幕| 99久久99这里只有免费费精品| 一本色道久久综合狠狠躁篇| 精品久久久久久无码人妻蜜桃| 久久人人爽爽爽人久久久| 久久人人青草97香蕉| 国产精品欧美久久久久无广告| 嫩草伊人久久精品少妇AV| 国产精品久久婷婷六月丁香| 久久久久99精品成人片牛牛影视| 久久精品国产免费| 国内精品久久久久久99| 久久国产劲爆AV内射—百度| 亚洲精品高清一二区久久| 久久人妻少妇嫩草AV蜜桃| 成人午夜精品久久久久久久小说| 久久91精品国产91久久小草| 国产亚洲精品美女久久久| 日日噜噜夜夜狠狠久久丁香五月| 久久亚洲sm情趣捆绑调教| 青青草原综合久久大伊人| 少妇人妻综合久久中文字幕| 精品久久久久久久国产潘金莲| 久久亚洲精品国产精品婷婷| 伊人久久大香线蕉av一区|