第六章 指針和結(jié)構(gòu)類型的關(guān)系
可以聲明一個(gè)指向結(jié)構(gòu)類型對(duì)象的指針。
例十一:
struct MyStruct
{
int a;
int b;
int c;
}
MyStruct ss={20,30,40};//聲明了結(jié)構(gòu)對(duì)象ss,并把ss的三個(gè)成員初始
化為20,30和40。
MyStruct *ptr=&ss;//聲明了一個(gè)指向結(jié)構(gòu)對(duì)象ss的指針。它的類型是
MyStruct*,它指向的類型是MyStruct。
int *pstr=(int*)&ss;//聲明了一個(gè)指向結(jié)構(gòu)對(duì)象ss的指針。但是它的
類型和它指向的類型和ptr是不同的。
請(qǐng)問(wèn)怎樣通過(guò)指針ptr來(lái)訪問(wèn)ss的三個(gè)成員變量?
答案:
ptr->a;
ptr->b;
ptr->c;
又請(qǐng)問(wèn)怎樣通過(guò)指針pstr來(lái)訪問(wèn)ss的三個(gè)成員變量?
答案:
*pstr;//訪問(wèn)了ss的成員a。
*(pstr+1);//訪問(wèn)了ss的成員b。
*(pstr+2)//訪問(wèn)了ss的成員c。
呵呵,雖然我在我的MSVC++6.0上調(diào)式過(guò)上述代碼,但是要知道,這樣使用p
str來(lái)訪問(wèn)結(jié)構(gòu)成員是不正規(guī)的,為了說(shuō)明為什么不正規(guī),讓我們看看怎樣通過(guò)指
針來(lái)訪問(wèn)數(shù)組的各個(gè)單元:
例十二:
int array[3]={35,56,37};
int *pa=array;
通過(guò)指針pa訪問(wèn)數(shù)組array的三個(gè)單元的方法是:
*pa;//訪問(wèn)了第0號(hào)單元
*(pa+1);//訪問(wèn)了第1號(hào)單元
*(pa+2);//訪問(wèn)了第2號(hào)單元
從格式上看倒是與通過(guò)指針訪問(wèn)結(jié)構(gòu)成員的不正規(guī)方法的格式一樣。
所有的C/C++編譯器在排列數(shù)組的單元時(shí),總是把各個(gè)數(shù)組單元存放在連續(xù)的
存儲(chǔ)區(qū)里,單元和單元之間沒(méi)有空隙。但在存放結(jié)構(gòu)對(duì)象的各個(gè)成員時(shí),在某種
編譯環(huán)境下,可能會(huì)需要字對(duì)齊或雙字對(duì)齊或者是別的什么對(duì)齊,需要在相鄰兩
個(gè)成員之間加若干個(gè)“填充字節(jié)”,這就導(dǎo)致各個(gè)成員之間可能會(huì)有若干個(gè)字節(jié)
的空隙。
所以,在例十二中,即使*pstr訪問(wèn)到了結(jié)構(gòu)對(duì)象ss的第一個(gè)成員變量a,也
不能保證*(pstr+1)就一定能訪問(wèn)到結(jié)構(gòu)成員b。因?yàn)槌蓡Ta和成員b之間可能會(huì)有
若干填充字節(jié),說(shuō)不定*(pstr+1)就正好訪問(wèn)到了這些填充字節(jié)呢。這也證明了指
針的靈活性。要是你的目的就是想看看各個(gè)結(jié)構(gòu)成員之間到底有沒(méi)有填充字節(jié),
嘿,這倒是個(gè)不錯(cuò)的方法。
通過(guò)指針訪問(wèn)結(jié)構(gòu)成員的正確方法應(yīng)該是象例十二中使用指針ptr的方法。
可以聲明一個(gè)指向結(jié)構(gòu)類型對(duì)象的指針。
例十一:
struct MyStruct
{
int a;
int b;
int c;
}
MyStruct ss={20,30,40};//聲明了結(jié)構(gòu)對(duì)象ss,并把ss的三個(gè)成員初始
化為20,30和40。
MyStruct *ptr=&ss;//聲明了一個(gè)指向結(jié)構(gòu)對(duì)象ss的指針。它的類型是
MyStruct*,它指向的類型是MyStruct。
int *pstr=(int*)&ss;//聲明了一個(gè)指向結(jié)構(gòu)對(duì)象ss的指針。但是它的
類型和它指向的類型和ptr是不同的。
請(qǐng)問(wèn)怎樣通過(guò)指針ptr來(lái)訪問(wèn)ss的三個(gè)成員變量?
答案:
ptr->a;
ptr->b;
ptr->c;
又請(qǐng)問(wèn)怎樣通過(guò)指針pstr來(lái)訪問(wèn)ss的三個(gè)成員變量?
答案:
*pstr;//訪問(wèn)了ss的成員a。
*(pstr+1);//訪問(wèn)了ss的成員b。
*(pstr+2)//訪問(wèn)了ss的成員c。
呵呵,雖然我在我的MSVC++6.0上調(diào)式過(guò)上述代碼,但是要知道,這樣使用p
str來(lái)訪問(wèn)結(jié)構(gòu)成員是不正規(guī)的,為了說(shuō)明為什么不正規(guī),讓我們看看怎樣通過(guò)指
針來(lái)訪問(wèn)數(shù)組的各個(gè)單元:
例十二:
int array[3]={35,56,37};
int *pa=array;
通過(guò)指針pa訪問(wèn)數(shù)組array的三個(gè)單元的方法是:
*pa;//訪問(wèn)了第0號(hào)單元
*(pa+1);//訪問(wèn)了第1號(hào)單元
*(pa+2);//訪問(wèn)了第2號(hào)單元
從格式上看倒是與通過(guò)指針訪問(wèn)結(jié)構(gòu)成員的不正規(guī)方法的格式一樣。
所有的C/C++編譯器在排列數(shù)組的單元時(shí),總是把各個(gè)數(shù)組單元存放在連續(xù)的
存儲(chǔ)區(qū)里,單元和單元之間沒(méi)有空隙。但在存放結(jié)構(gòu)對(duì)象的各個(gè)成員時(shí),在某種
編譯環(huán)境下,可能會(huì)需要字對(duì)齊或雙字對(duì)齊或者是別的什么對(duì)齊,需要在相鄰兩
個(gè)成員之間加若干個(gè)“填充字節(jié)”,這就導(dǎo)致各個(gè)成員之間可能會(huì)有若干個(gè)字節(jié)
的空隙。
所以,在例十二中,即使*pstr訪問(wèn)到了結(jié)構(gòu)對(duì)象ss的第一個(gè)成員變量a,也
不能保證*(pstr+1)就一定能訪問(wèn)到結(jié)構(gòu)成員b。因?yàn)槌蓡Ta和成員b之間可能會(huì)有
若干填充字節(jié),說(shuō)不定*(pstr+1)就正好訪問(wèn)到了這些填充字節(jié)呢。這也證明了指
針的靈活性。要是你的目的就是想看看各個(gè)結(jié)構(gòu)成員之間到底有沒(méi)有填充字節(jié),
嘿,這倒是個(gè)不錯(cuò)的方法。
通過(guò)指針訪問(wèn)結(jié)構(gòu)成員的正確方法應(yīng)該是象例十二中使用指針ptr的方法。