方法是在定義變量的同時(shí)給其一初始值。結(jié)構(gòu)體變量的初始化,遵循相同的規(guī)律。
創(chuàng)新互聯(lián)專(zhuān)業(yè)為企業(yè)提供奉化網(wǎng)站建設(shè)、奉化做網(wǎng)站、奉化網(wǎng)站設(shè)計(jì)、奉化網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、奉化企業(yè)網(wǎng)站模板建站服務(wù),10余年奉化做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
也可以采取申明類(lèi)型與定義變量分開(kāi)的形式,在定義變量時(shí)進(jìn)行初始化:student student1 = {10001,zhangxin} 。在C語(yǔ)言中,結(jié)構(gòu)體(struct)指的是一種數(shù)據(jù)結(jié)構(gòu),是C語(yǔ)言中聚合數(shù)據(jù)類(lèi)型(aggregate data type)的一類(lèi)。
初始化列表 一個(gè)類(lèi)/結(jié)構(gòu)的構(gòu)造函數(shù)可以在定義中于構(gòu)造函數(shù)體前包含一個(gè)初始化列表,用以給類(lèi)/結(jié)構(gòu)的元素賦初值。
不是inta[] 而是例如int a[10]這種。括號(hào)內(nèi)一定要有個(gè)常量數(shù)字。
結(jié)構(gòu)體是個(gè)空架子,是無(wú)法“初始化其中的數(shù)組”的,只有初始化結(jié)構(gòu)體的對(duì)象(即變量)。像你這里可以這么做:在使用這個(gè)結(jié)構(gòu)體前寫(xiě)一句struct bf x={NULL,NULL,NULL,NULL};,那么x中的所有字符數(shù)組就都為空了。
等調(diào)用完Create()后,pr還是會(huì)消亡的,回到main,時(shí),這里的pr1就是另一個(gè)List變量了。總而言之,Creat()里面的pr和main()里面的pr1是完全不同的兩個(gè)變量。要想讓他們變成一個(gè)變量。可選用指針傳參。
結(jié)構(gòu)體數(shù)組需要一個(gè)一個(gè)賦值,沒(méi)有你這樣的寫(xiě)法。
struct student { int num; char name; float score[3]} stu = {1, m, {90.1, 90.2, 90.3}};這樣就行了,原題中的那個(gè)不叫初始化。
); //%c前一定要有空格 scanf(%d, &(stu[i].age));for (int j=0; j3; j++)scanf(%f, &(stu[i].score[j]));scanf(%d, &(stu[i].class));} 取地址符前的括號(hào)可以不要,要更加清晰。
1、在初始化函數(shù)中,首先參數(shù)sqlist *L,應(yīng)該改成Sqlist *L 然后你給L-Elem_array進(jìn)行賦值操作是不對(duì)的,因?yàn)镋lem_array是數(shù)組首地址,是個(gè)常量,不能進(jìn)行賦值操作。
2、C數(shù)據(jù)結(jié)構(gòu)的基礎(chǔ)是指針。好好花上幾天時(shí)間把指針搞懂再來(lái)學(xué)數(shù)據(jù)結(jié)構(gòu)會(huì)事半功倍。
3、這里提供兩種創(chuàng)建順序表的代碼,一種是由系統(tǒng)分配list占用的內(nèi)存,一種是自己動(dòng)態(tài)分配的內(nèi)存,需要在程序運(yùn)行之前手動(dòng)釋放占用的內(nèi)存空間。
4、P是個(gè)指針變量,實(shí)際的意思是指向一個(gè)內(nèi)存地址,當(dāng)p=(char *)malloc(2) 后,p即指向了malloc函數(shù)所分配的內(nèi)存區(qū)的首地址了,并且告訴你從首地址開(kāi)始后面兩個(gè)字節(jié)可用,即P[0],p[1]是可用的。