• <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>

            統(tǒng)計(jì)

            • 隨筆 - 50
            • 文章 - 42
            • 評(píng)論 - 147
            • 引用 - 0

            留言簿(6)

            隨筆分類

            文章分類

            Link

            搜索

            •  

            積分與排名

            • 積分 - 164634
            • 排名 - 159

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用(一)

            MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用

            前言:本文之所以強(qiáng)調(diào)MSVC, 旨在提醒讀者在不同平臺(tái)和解釋器下內(nèi)存布局和實(shí)現(xiàn)上存在差異,但編程思想通用,文中內(nèi)容大多來自筆者實(shí)際工作經(jīng)驗(yàn)和網(wǎng)上搜集,力求正確,但水平有限,如有不當(dāng)之處,敬請(qǐng)指出

            面向?qū)ο螅罕疚拿嫦蛴幸欢?/span>C/C++基礎(chǔ),并且可以讀懂部分匯編的讀者

            版權(quán):歡迎轉(zhuǎn)載,但請(qǐng)注明出處http://www.shnenglu.com/dawnbreak/ 保留對(duì)本文的一切權(quán)力

            目錄
            1. C++基本類型與結(jié)構(gòu)體內(nèi)存布局
                            Key words: class,  struct, memory alignment

            2.虛表, 多態(tài)與動(dòng)態(tài)綁定

                            Key words: Virtual Table, polymiorphism

            3.對(duì)象池

                            Key words: object pool , reload, new ,delete

            4.內(nèi)存泄漏檢測(cè)

                            Key words: memory leak detect

            5.智能指針

                            Key words: smart pointer

            6.   編譯期類型約束
               
                            Key words: compile-time ,type-constraint


             Appendix 1: C++堆棧祥解




            第一篇:
            C++基本類型與結(jié)構(gòu)體內(nèi)存布局

             Reference: http://cnblogs.com/itech
            Key words: class,  struct, memory alignment

            1. 基本類型(basic type

              
             1//test the size of class and struct
             2void TestBasicSizeOf() 
             3
             4    cout << __FUNCTION__ << endl; 
             5    cout << "  sizeof(char)= " << sizeof ( char ) << endl; 
             6    cout << "  sizeof(int)= " << sizeof ( int ) << endl; 
             7    cout << "  sizeof(float)= " << sizeof ( float ) << endl; 
             8    cout << "  sizeof(double)= " << sizeof ( double ) << endl; 
             9
            10    cout << "  sizeof('$')=" << sizeof ( '$' ) << endl; 
            11    cout << "  sizeof(1)= " << sizeof ( 1 ) << endl; 
            12    cout << "  sizeof(1.5f)= " << sizeof ( 1.5f ) << endl; 
            13    cout << "  sizeof(1.5)= " << sizeof ( 1.5 ) << endl; 
            14
            15    cout << "  sizeof(Good!)= " << sizeof ( "Good!" ) << endl ; 
            16
            17    char  str[] = "CharArray!"
            18    int  a[10];  
            19    double  xy[10]; 
            20    cout << "  char str[] = \"CharArray!\"," << " sizeof(str)= " << sizeof (str) << endl; 
            21    cout << "  int a[10]," << " sizeof(a)= " << sizeof (a) << endl; 
            22    cout << "  double xy[10]," << " sizeof(xy)= " <<   sizeof (xy) << endl; 
            23
            24    cout << "  sizeof(void*)= " << sizeof(void*<< endl; 
            25}
            輸出結(jié)果:

            2. 結(jié)構(gòu)體與類

            這里的代碼是結(jié)構(gòu)體,但是結(jié)構(gòu)體和類在C++中是通用的,唯一的區(qū)別就是默認(rèn)的訪問方式,struct-public, class-private

             1struct st1
             2{
             3    short number;
             4    float math_grade;
             5    float Chinese_grade;
             6    float sum_grade;
             7    char  level;
             8}
            //20
             9
            10struct st2
            11{
            12    char  level;
            13    short number;
            14    float math_grade;
            15    float Chinese_grade;
            16    float sum_grade;
            17}
            ;//16
            18
            19#pragma pack(1)
            20struct st3
            21{
            22    char  level;
            23    short number;
            24    float math_grade;
            25    float Chinese_grade;
            26    float sum_grade;
            27}
            //15
            28#pragma pack() 
            29
            30void TestStructSizeOf()
            31{
            32    cout << __FUNCTION__ << endl;
            33
            34    cout << "  sizeof(st1)= " << sizeof (st1) << endl;
            35    cout << "  offsetof(st1,number) " << offsetof(st1,number) << endl;
            36    cout << "  offsetof(st1,math_grade) " << offsetof(st1,math_grade) << endl;
            37    cout << "  offsetof(st1,Chinese_grade) " << offsetof(st1,Chinese_grade) << endl;
            38    cout << "  offsetof(st1,sum_grade) " << offsetof(st1,sum_grade) << endl;
            39    cout << "  offsetof(st1,level) " << offsetof(st1,level) << endl;
            40
            41    cout << "  sizeof(st2)= " << sizeof (st2) << endl;
            42    cout << "  offsetof(st2,level) " << offsetof(st2,level) << endl;
            43    cout << "  offsetof(st2,number) " << offsetof(st2,number) << endl;
            44    cout << "  offsetof(st2,math_grade) " << offsetof(st2,math_grade) << endl;
            45    cout << "  offsetof(st2,Chinese_grade) " << offsetof(st2,Chinese_grade) << endl;
            46    cout << "  offsetof(st2,sum_grade) " << offsetof(st2,sum_grade) << endl;
            47
            48
            49    cout << "  sizeof(st3)= " << sizeof (st3) << endl;
            50    cout << "  offsetof(st3,level) " << offsetof(st3,level) << endl;
            51    cout << "  offsetof(st3,number) " << offsetof(st3,number) << endl;
            52    cout << "  offsetof(st3,math_grade) " << offsetof(st3,math_grade) << endl;
            53    cout << "  offsetof(st3,Chinese_grade) " << offsetof(st3,Chinese_grade) << endl;
            54    cout << "  offsetof(st3,sum_grade) " << offsetof(st3,sum_grade) << endl;
            55}

            輸出結(jié)果:

            3.內(nèi)存對(duì)齊

            仔細(xì)查看上面的輸出結(jié)果,會(huì)發(fā)現(xiàn)同樣的結(jié)構(gòu)體定義僅僅是成員順序不同, 就會(huì)造成結(jié)構(gòu)體大小的變化,這就是內(nèi)存對(duì)齊的結(jié)果,在計(jì)算機(jī)的底層進(jìn)行內(nèi)存的讀寫的時(shí)候,如果內(nèi)存對(duì)齊的話可以提高讀寫效率,下面是VC的默認(rèn)的內(nèi)存對(duì)齊規(guī)則:

            1) 結(jié)構(gòu)體變量的首地址能夠被其最寬基本類型成員的大小所整除;
            2)
            結(jié)構(gòu)體每個(gè)成員相對(duì)于結(jié)構(gòu)體首地址的偏移量(offset)都是成員大小的整數(shù)倍, 如有需要編譯器會(huì)在成員之間加上填充字節(jié)(internal adding);
            3)
            結(jié)構(gòu)體的總大小為結(jié)構(gòu)體最寬基本類型成員大小的整數(shù)倍,如有需要編譯器會(huì)在最末一個(gè)成員之后加上填充字節(jié)(trailing padding)。

            當(dāng)然VC提供了工程選項(xiàng)/Zp [1|2|4|8|16]可以修改對(duì)齊方式,當(dāng)然我們也可以在代碼中對(duì)部分類型實(shí)行特殊的內(nèi)存對(duì)齊方式,修改方式為#pragma pack( n )n為字節(jié)對(duì)齊
            數(shù),其取值為124816,默認(rèn)是8,取消修改用#pragma pack(),如果結(jié)構(gòu)體某成員的sizeof大于你設(shè)置的,則按你的設(shè)置來對(duì)齊。

            本章結(jié)束

             

             

            posted on 2009-03-10 12:57 pear_li 閱讀(2803) 評(píng)論(8)  編輯 收藏 引用 所屬分類: C++

            評(píng)論

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-11 09:01 megax

            還有下文沒?

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-11 09:39 夢(mèng)在天涯

            1. C++基本類型與結(jié)構(gòu)體內(nèi)存布局
            Key words: class, struct, memory alignment

            2.虛表, 多態(tài)與動(dòng)態(tài)綁定

            Key words: Virtual Table, polymiorphism

            我覺的我總結(jié)的還是不錯(cuò)的哦,你可以直接轉(zhuǎn)載好了,轉(zhuǎn)載請(qǐng)注明出處!其實(shí)我還有準(zhǔn)備下一系列,但是實(shí)在是最近太忙了,所以暫停了啊!

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-11 09:40 夢(mèng)在天涯

            你可以到我的cnblogs.com/itech上加我的msn!

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-14 10:04 gifty

            內(nèi)存對(duì)齊默認(rèn)是4吧!

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-16 17:48 pear_li

            @gifty
            對(duì)于32位系統(tǒng)是4位,對(duì)于64位系統(tǒng)是8位
            仁兄看得真仔細(xì)

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-03-26 21:18 可微函數(shù)

            采用自定義的對(duì)齊方式 是不是會(huì)對(duì)訪問效率產(chǎn)生影響?

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2009-04-02 22:17 pear_li

            @可微函數(shù)
            對(duì),會(huì)產(chǎn)生很大的影響,因?yàn)榘凑誜86尋址方式,如果數(shù)據(jù)沒有對(duì)其,默認(rèn)方式會(huì)先將數(shù)據(jù)對(duì)其再進(jìn)行操作,而對(duì)于IA64的機(jī)器情況更糟,系統(tǒng)會(huì)終止執(zhí)行你的程序

            # re: MSVC++ 對(duì)象內(nèi)存模型深入解析與具體應(yīng)用 2010-04-03 19:10 sasa官網(wǎng)

            分析的到位 :)
            狠狠色伊人久久精品综合网| 亚洲AV无码久久| 久久久久综合国产欧美一区二区| 2020最新久久久视精品爱| 国产伊人久久| 三级片免费观看久久| 思思久久99热只有频精品66| 亚洲午夜久久久影院| 国产日产久久高清欧美一区| 91精品国产91久久久久久青草 | 精品国产综合区久久久久久| 久久最新免费视频| 日本强好片久久久久久AAA| 欧美激情精品久久久久| 亚洲欧洲中文日韩久久AV乱码| 一本色道久久综合狠狠躁| 久久最近最新中文字幕大全| 亚洲国产精品综合久久网络| 久久精品国产亚洲精品2020| 久久久久一本毛久久久| 久久天天躁狠狠躁夜夜躁2O2O| 精品一久久香蕉国产线看播放| 亚洲AV无码一区东京热久久| 国产精品内射久久久久欢欢| 亚洲精品无码久久久久去q| 久久高潮一级毛片免费| 久久国产色AV免费观看| 深夜久久AAAAA级毛片免费看| 精品一区二区久久| 97精品依人久久久大香线蕉97| 精品久久人人做人人爽综合| 色欲综合久久躁天天躁蜜桃| 久久99精品国产麻豆婷婷| 国产亚洲精品美女久久久| 久久久无码精品亚洲日韩蜜臀浪潮| 久久综合狠狠综合久久激情 | 久久久久久人妻无码| 一本综合久久国产二区| 久久精品国产第一区二区| 国产精品岛国久久久久| 亚洲中文字幕无码久久2020|