關(guān)于偏移量的宏定義
#define offsetof(s,m) (size_t)&(((s *)0)->m)
s是一個(gè)結(jié)構(gòu)名,它有一個(gè)名為m的成員(s和m 是宏offsetof的形參,
它實(shí)際是返回結(jié)構(gòu)s的成員m的偏移地址
(s *)0 是騙編譯器說有一個(gè)指向類(或結(jié)構(gòu))s的指針,其地址值0
&((s *)0)->m 是要取得類s中成員變量m的地址
因基址為0,這時(shí)m的地址當(dāng)然就是m在s中的偏移
最后轉(zhuǎn)換size_t 型,即unsigned int。
有例子如:
struct AAA
{
int i;
int j;
};
struct AAA *pAAA;
pAAA = new AAA;
這時(shí),pAAA實(shí)際上是一個(gè)Pointer, 指向某一確定的內(nèi)存地址,
如0x1234;
而pAAA->i 整體是一個(gè)int型變量,其地址是&(pAAA->i),
'&'為取址運(yùn)算符;
那么&(pAAA->i)一定等于0x1234,因 i 是結(jié)構(gòu)體AAA的第一個(gè)元素。
而&(pAAA->j)一定是0x1234 + 0x4 = 0x1238; 因?yàn)閟izeof(int) = 4;
這個(gè)做法的巧妙之處就是:它把“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這個(gè)元素了,而&(pS->m)就是m的地址,
就是offset啦