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

            天行健 君子當自強而不息

            offsetof宏解析


            今天看代碼時,發(fā)現(xiàn)一個有用的東東,offsetof(s,m),這是一個宏,MSDN文檔的說明如下:

            Retrieves the offset of a member from the beginning of its parent structure.

            size_t offsetof(
            structName,
            memberName
            );


            Parameters

            structName
            Name of the parent data structure.


            memberName
            Name of the member in the parent data structure for which to determine the offset.


            Return Value


            offsetof returns the offset in bytes of the specified member from the beginning of its parent data structure. It is undefined for bit fields.

            Remarks

            The offsetof macro returns the offset in bytes of memberName from the beginning of the structure specified by structName. You can specify types with the struct keyword.

            Note


            offsetof is not a function and cannot be described using a C prototype.

            跟蹤代碼發(fā)現(xiàn)定義如下:

            #define offsetof(s,m) (size_t)&(((s *)0)->m)

            然后到網(wǎng)上查了一下,發(fā)現(xiàn)還真的是很有用,附帶一位大俠的解說:

            struct AAA
            {
                int i;
                int j;
            };

            struct AAA *pAAA;
            pAAA=new AAA;


            這時,pAAA實際上是一個Pointer, 指向某一確定的內(nèi)存地址,比如0x1234;
            而 pAAA->i 整體是一個int型變量,其地址是&(pAAA->i) ,'&'為取址運算符;
            那么&(pAAA->i)一定等于0x1234,因為i是結(jié)構體AAA的第一個元素。
            而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因為sizeof(int) = 4;

            這個做法的巧妙之處就是:它把“0”作為上例中的pAAA,那么 &(pAAA->j)就是j的offset啦。

            解析結(jié)果是:
            (s *)0 ,將 0 強制轉(zhuǎn)換為Pointer to "s"
            可以記 pS = (s *)0 ,pS是指向s的指針,它的值是0;
            那么pS->m就是m這個元素了,而&(pS->m)就是m的地址,而在本例中就是offset啦

            再把結(jié)果強制轉(zhuǎn)換為size_t型的就OK 了,size_t其實也就是int啦!!

            也就是說:

            0 ---> (s *)0

            原來的0是數(shù)值類型,現(xiàn)在是結(jié)構體指針類型,盡管類型變了,但其值還是不變,也就是說還是0,但這個值的意義變了,現(xiàn)在是地址,而不是數(shù)值。

            &(((s *)0)->m)求出字段m的地址值,但由于首地址是0,所以&(((s *)0)->m)求出字段m相對于首地址的偏移值。

            posted on 2007-09-24 19:04 lovedday 閱讀(3764) 評論(0)  編輯 收藏 引用 所屬分類: ▲ C Program

            公告

            導航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關鏈接

            搜索

            最新評論

            久久人人爽人人爽人人片AV东京热| 久久精品国产亚洲Aⅴ香蕉| 亚洲AV无码久久精品蜜桃| 久久99精品久久久久久久不卡| 国产亚洲欧美成人久久片| 一本综合久久国产二区| 狠狠色丁香婷婷综合久久来| 伊人久久成人成综合网222| 久久国产精品99精品国产987| 亚洲精品无码专区久久同性男| 亚洲AV无一区二区三区久久| 2020最新久久久视精品爱| 97久久国产露脸精品国产| 99久久精品免费看国产一区二区三区 | 热久久这里只有精品| 无夜精品久久久久久| 99久久免费国产精品热| 伊人久久大香线蕉综合影院首页 | 久久精品国产一区二区| 九九久久自然熟的香蕉图片| 久久频这里精品99香蕉久| 国产精品va久久久久久久| 久久精品国产精品国产精品污| 亚洲狠狠婷婷综合久久蜜芽| 久久国产精品无| 久久久久亚洲av毛片大| 久久99精品国产麻豆蜜芽| 一级做a爱片久久毛片| 丰满少妇人妻久久久久久4| 国产高潮久久免费观看| 欧美久久精品一级c片片| 免费观看成人久久网免费观看| 久久国产精品99久久久久久老狼| 狠狠88综合久久久久综合网| 国产V综合V亚洲欧美久久| 久久精品国产亚洲av麻豆色欲| 漂亮人妻被黑人久久精品| 久久亚洲私人国产精品| 国产精品一区二区久久精品| 99久久精品国内| 久久99久久成人免费播放|