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

            天行健 君子當(dāng)自強(qiáng)而不息

            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) ,'&'為取址運(yùn)算符;
            那么&(pAAA->i)一定等于0x1234,因為i是結(jié)構(gòu)體AAA的第一個元素。
            而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因為sizeof(int) = 4;

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

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

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

            也就是說:

            0 ---> (s *)0

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

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

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

            公告

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            隨筆分類(178)

            3D游戲編程相關(guān)鏈接

            搜索

            最新評論

            亚洲午夜精品久久久久久浪潮 | 精品久久久久久久久久中文字幕| 99久久人妻无码精品系列蜜桃| 亚洲国产精久久久久久久| 99久久亚洲综合精品成人| 亚洲人AV永久一区二区三区久久 | 少妇无套内谢久久久久| 一本一道久久综合狠狠老 | 亚洲成av人片不卡无码久久| 亚洲午夜久久久影院伊人| 99久久婷婷国产一区二区| 久久久久久久精品妇女99| 久久99精品久久久久婷婷| 久久笫一福利免费导航| 国产精品久久国产精麻豆99网站| 久久久久亚洲精品中文字幕 | 精品久久久久久久中文字幕| 国产69精品久久久久久人妻精品| 91精品国产综合久久香蕉| 无码国内精品久久人妻蜜桃| 婷婷久久综合九色综合九七| 国产韩国精品一区二区三区久久| 久久亚洲熟女cc98cm| 热RE99久久精品国产66热| 99久久99久久精品国产片| 亚洲国产精品久久久天堂| 亚洲精品视频久久久| 青青热久久国产久精品 | 三级三级久久三级久久 | 久久99精品久久久久久齐齐| 久久电影网一区| 77777亚洲午夜久久多喷| 久久99精品久久久久久久不卡 | 国产一区二区久久久| 亚洲另类欧美综合久久图片区| 久久av免费天堂小草播放| 国产精品免费久久久久久久久| 久久免费小视频| 99久久99久久精品国产| 久久久精品视频免费观看| 久久天天躁狠狠躁夜夜2020|