• <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 閱讀(9981) 評論(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久久精品国产91性色也| 久久久久综合国产欧美一区二区 | 香蕉aa三级久久毛片| 2020国产成人久久精品| 亚洲愉拍99热成人精品热久久| 久久久国产乱子伦精品作者| 999久久久国产精品| 午夜不卡久久精品无码免费| 91精品国产91久久久久久青草| 久久笫一福利免费导航| 久久久久久久尹人综合网亚洲 | 一个色综合久久| 久久国产精品久久久| 久久久久波多野结衣高潮| 99热成人精品免费久久| 久久夜色精品国产噜噜噜亚洲AV| segui久久国产精品| 久久久久人妻精品一区| 中文字幕无码久久人妻| 精品久久久久久国产免费了| 久久精品国产99国产精偷| 亚洲午夜久久久久久久久电影网| 一本久久综合亚洲鲁鲁五月天| 久久精品免费观看| 久久精品国产亚洲精品2020| 久久婷婷五月综合国产尤物app| 久久国产精品国语对白| 久久精品国产99国产电影网| 亚洲精品美女久久久久99| 久久精品一区二区三区AV| 国内精品久久久久影院亚洲| 精品水蜜桃久久久久久久| 99久久国产主播综合精品| 精品免费tv久久久久久久| 久久久久人妻精品一区二区三区| 老色鬼久久亚洲AV综合| 久久天天躁狠狠躁夜夜96流白浆| 久久人人爽人人爽人人片AV不| 久久亚洲中文字幕精品一区| 久久精品无码一区二区WWW| 77777亚洲午夜久久多喷|