C語(yǔ)言筆記第六章指針和結(jié)構(gòu)類型的關(guān)系

字號(hào):

第六章 指針和結(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的方法。