轉自http://www.jb51.net/article/42140.htmios
定義:數組
結構體變量的指針就是該變來那個所佔據的內存段的起始地址。能夠設一個指針變量,來指向一個結構體變量,此時該指針變量的值是結構體變量的起始地址。spa
設p是指向結構體變量的數組,則能夠經過如下的方式,調用指向的那個結構體中的成員:.net
(1)結構體變量.成員名。如,stu.num。指針
(2)(*p).成員名。如,(*p).num。htm
(3)p->成員名。如,p->num。
blog
代碼以下:內存
#include<iostream> #include<string> using namespace std; struct Candidate{ string name; int count; }; int main(){ Candidate c_leader[2]={"Tom",5,"Marry",8}; Candidate *p1,*p2; p1=c_leader; cout<<(*p1).name<<":"<<(*p1).count<<endl; p2=&c_leader[1]; cout<<p2->name<<":"<<p2->count<<endl; return 0; }
說明,結構體數組也和其餘數組同樣,一維數組的數組表明首個元素的地址string
咱們瞭解到,結構體中能夠包含不少類型的成員變量,那麼能否包含指針變量成員呢?答案是能夠的。io
那麼是否也能夠包含指向同類結構的結構體變量呢?固然能夠,鏈表就是應用了這個原理。
#include<iostream> #include<string> using namespace std; struct Candidate{ string name; int count; Candidate *next;//定義了指向Candidate類型變量的指針 }; int main(){ Candidate c_leader[3]; c_leader[0].name="Tom"; c_leader[0].count=5; c_leader[0].next=&c_leader[1]; c_leader[1].name="Nick"; c_leader[1].count=9; c_leader[1].next=&c_leader[2]; c_leader[2].name="Jim"; c_leader[2].count=10; c_leader[2].next=NULL; Candidate *p=c_leader; while(p!=NULL){ cout<<p->name<<":"<<p->count<<endl; //也能夠(p+1)->name...來實現 p=p->next; } return 0; }