• <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>
            asm, c, c++ are my all
            -- Core In Computer
            posts - 139,  comments - 123,  trackbacks - 0

            ********************************************\
            |????歡迎轉載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!???? |
            \********************************************/


            C++對象模型(10) - 3.2 Data Member Layout

            作者: Jerry Cat
            時間: 2006/11/15
            鏈接:?
            http://m.shnenglu.com/jerysun0818/archive/2006/11/15/15192.html


            3.2 Data Member Layout

            class Point3d {
            public:
            ?? // ...
            private:
            ?? float x;
            ?? static List<Point3d*> *freeList;
            ?? float y;
            ?? static const int chunkSize = 250;
            ?? float z;
            };
            the nonstatic data members are set down in the order of their declaration(按聲明的順序) within each class object (any intervening static data members, such as freeList and chunkSize, are ignored). In our example, then, each Point3d object consists of three float members in order: x, y, z. The static data members are stored in the program's data segment independent of individual class objects.

            The Standard requires within an access section (the private, public, or protected section of a class declaration) only that the members be set down such that "later members have higher addresses within a class object" (Section 9.2 of the Standard). That is, the members are not required to be set down contiguously.(可以不連續但必須從低到高)

            What might intervene between the declared members? Alignment constraints on the type of a succeeding member may require padding. This is true both of C and C++, and in this case, the member layout of the two languages is in current practice the same.(對齊)

            虛表指針在哪兒? Traditionally, it has been placed after all the explicitly declared members of the class. More recently, it has been placed at the beginning of the class object. The Standard, by phrasing the layout requirement as it does, allows the compiler the freedom to insert these internally generated members anywhere, even between those explicitly declared by the programmer.

            In practice, multiple access sections are concatenated together into one contiguous block in the order of declaration.編譯器幫你同類項合并 No overhead is incurred by the access section specifier or the number of access levels. For example, declaring eight members in one access section or eight separate access sections in practice results in the same-sized objects.

            posted on 2006-11-15 23:34 Jerry Cat 閱讀(1000) 評論(0)  編輯 收藏 引用

            <2006年10月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久笫一福利免费导航 | 午夜精品久久久久久久久| 一级做a爰片久久毛片毛片| 狠狠色狠狠色综合久久| 国内精品久久久久久99| 久久久久亚洲av无码专区导航| 午夜精品久久久久久99热| 国产一区二区精品久久| 精品熟女少妇aⅴ免费久久| 人妻无码精品久久亚瑟影视| 国产精品18久久久久久vr| 久久精品国产亚洲av瑜伽| 欧美一区二区三区久久综合| 亚洲国产成人久久综合碰碰动漫3d| 亚洲国产精品成人久久蜜臀 | 亚洲精品tv久久久久久久久| 久久综合久久综合九色| 伊人 久久 精品| 精品久久久久国产免费| 国产亚洲精品美女久久久| 亚洲精品午夜国产va久久| 99久久精品国内| 色婷婷综合久久久久中文一区二区 | 一级做a爰片久久毛片16| 久久婷婷五月综合色奶水99啪| 91久久精品无码一区二区毛片| 午夜欧美精品久久久久久久| 午夜精品久久久久久影视777| 国产成人精品久久免费动漫| 亚洲国产精品18久久久久久| 久久国产亚洲精品| 国产69精品久久久久APP下载| 久久93精品国产91久久综合| 亚洲国产精品久久久久婷婷软件| 国产亚洲综合久久系列| 国产精品久久成人影院| 久久99国内精品自在现线| 囯产精品久久久久久久久蜜桃| 久久久这里只有精品加勒比 | 少妇精品久久久一区二区三区| 伊人久久综合无码成人网 |