国产18禁黄网站免费观看,99爱在线精品免费观看,粉嫩metart人体欣赏,99久久99精品久久久久久,6080亚洲人久久精品

C/C++中結(jié)構(gòu)體(struct)知識(shí)點(diǎn)強(qiáng)化(二)

時(shí)間:2008-10-04 04:25:00   來(lái)源:無(wú)憂考網(wǎng)     [字體: ]
程序種有兩個(gè)組成部分
   test *create()
   和 void showl(test *head)
   這兩個(gè)函數(shù),create是用來(lái)創(chuàng)建鏈表的 ,showl是用來(lái)顯示鏈表的。

   create函數(shù)的返回類(lèi)型是一個(gè)結(jié)構(gòu)體指針,在程序調(diào)用的時(shí)候我們用了showl(create());,而不用引用的目的原因是引導(dǎo)指針是一個(gè)全局指針變量,我們不能在showl()內(nèi)改變它,因?yàn)閟howl()函數(shù)內(nèi)有一個(gè)移動(dòng)操作head=head->next;,如果是引用的話我們就破壞了head指針的位置,以至于我們?cè)僖矡o(wú)法找會(huì)首地址的位置了。

   下面我們來(lái)分解整個(gè)程序,以一個(gè)初學(xué)者的思想來(lái)思考整個(gè)程序,由淺入深的逐步解釋。

   首先,我們寫(xiě)這個(gè)程序,要考慮到由于是一個(gè)鏈表結(jié)構(gòu),我們不可能知道它的大小到底是多大,這個(gè)問(wèn)題我們可以用動(dòng)態(tài)開(kāi)辟堆內(nèi)存來(lái)解決,因?yàn)槎褍?nèi)存在程序結(jié)束前始終是有效的,不受函數(shù)?臻g生命期的限制,但要注意的是我們必須有一個(gè)指針變量來(lái)存儲(chǔ)這一鏈狀結(jié)構(gòu)的進(jìn)入地址,而在函數(shù)內(nèi)部來(lái)建立這一指針變量顯然是不合適的,因?yàn)楹瘮?shù)一旦退出,這個(gè)指針變量也隨之失效,所以我們?cè)诔绦虻拈_(kāi)始聲明了一個(gè)全局指針變量。來(lái)源:www.examda.com

   test *head;//創(chuàng)建一個(gè)全局的引導(dǎo)進(jìn)入鏈表的指針
   好解決了這兩個(gè)問(wèn)題,我們接下去思考

   有輸入就必然有輸出,由于輸出函數(shù)和輸入函數(shù)是相對(duì)獨(dú)立的,為了不斷測(cè)試程序的正確性好調(diào)試我們先寫(xiě)好輸出函數(shù)和main函數(shù)捏的調(diào)用,創(chuàng)建函數(shù)我們先約定好名為create。

   我們先寫(xiě)出如下的代碼:

   #include
   using namespace std;

   struct test
   {
   char name[10];
   float socre;
   test *next;
   };

   test *head;//創(chuàng)建一個(gè)全局的引導(dǎo)進(jìn)入鏈表的指針

   test *create()
   {

   return head;//返回鏈?zhǔn)字羔?
   }

   void showl(test *head)
   {
   cout<<"鏈?zhǔn)字羔?"< <
   while(head)//以?xún)?nèi)存指向?yàn)閚ull為條件循環(huán)顯示先前輸入的內(nèi)容
   {
   cout< name<<"|"< socre<
   head=head->next;
   }
   }

   void main()
   {
   showl(create());
   cin.get();
   cin.get();
   }
   程序?qū)懙竭@里,基本形態(tài)已經(jīng)出來(lái),輸入和調(diào)用我們已經(jīng)有了。