因?yàn)樽约侯愋偷淖兞吭谶@個(gè)類型中定義時(shí),是不完整類型,除非你完成定義,不然不會(huì)知道這個(gè)類型的大小,而且本身嵌套本身,就等于是無(wú)窮遞歸的展開(kāi)了。
創(chuàng)新互聯(lián)公司是一家專注于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),順城網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)十年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:順城等地區(qū)。順城做網(wǎng)站價(jià)格咨詢:028-86922220
但指針就不同了,C語(yǔ)言的指針大小是4個(gè)字節(jié),他只是指向一個(gè)地址,和其他的全部無(wú)關(guān),他不需要知道自己類型有多大,有怎樣的結(jié)構(gòu)什么的,這些都不是他該關(guān)心的,他只要指向一個(gè)正確的地址就OK了,這就是指針的職責(zé)。定義指針是確定,不會(huì)影響該類型的結(jié)構(gòu),也不會(huì)出現(xiàn)無(wú)窮遞歸展開(kāi),所以在結(jié)構(gòu)體中定義自身指針是合法的。
//在結(jié)構(gòu)體中包含函數(shù)指針,
//這樣,可以使用結(jié)構(gòu)體,調(diào)用函數(shù)。
//這個(gè)有點(diǎn)像C++的面向?qū)ο蟮念?
//十分好用。?
#include?"stdio.h"??
struct?DEMO??
{??
int?x,y;??
int?(*func)(int,int);?//函數(shù)指針??
};??
int?add2(int?x,int?y)??
{??
return?x+y;??
}??
int?main()??
{
int?ret=0;
struct?DEMO?demo;??
demo.func=add2;?//結(jié)構(gòu)體函數(shù)指針賦值??
ret=demo.func(3,4);
printf("func(3,4)=%d\n",ret);??
}
首先解釋一下
st
的問(wèn)題吧:st
就是取結(jié)構(gòu)體的
st
的地址傳給結(jié)構(gòu)體內(nèi)的函數(shù)
p
和
o,
根據(jù)前面
st
的定義,也就是傳給
和
power。這樣
和
power
函數(shù)就可以讀取結(jié)構(gòu)體中的
i
和
x
值。
然后沿著各個(gè)思路,可以寫(xiě)出
和
power
函數(shù),如下:
void
print(ST
*st){
printf
("%g",
st-x);
}
void
power(ST
*st){
int
k;
double
y=1;
for
(k=0;k
i;k++)
y*=st-x;
st-x
=
y;
}
不過(guò)這里有個(gè)問(wèn)題,就是你之前的
struct
中定義的函數(shù)指針是沒(méi)有參數(shù)的,但是主函數(shù)調(diào)用時(shí)是有參數(shù)的,這是矛盾的呀。要改一下:
struct
ST{
int
i;
double
x;
void
(*o)(ST*);
void
(*p)(ST*);
}
;
就沒(méi)有問(wèn)題了。
指針就是指向內(nèi)存的某個(gè)地址的一個(gè)變量。
結(jié)構(gòu)體指針就是這個(gè)指針變量的值必須指向存放該結(jié)構(gòu)體的內(nèi)存位置。
當(dāng)這個(gè)指針沒(méi)有任何指向時(shí),可以賦值為null值,但是改指針不可使用,程序中應(yīng)該做判斷。下面是一些賦值演示。
struct student{
int id;
int score;
} aaa;
struct student *p = null;//結(jié)構(gòu)體指針p初始化賦值為null
struct student *p2=aaa;//p2指向aaa
struct student *p3=(struct student *)malloc(sizeof(struct student));//內(nèi)存中申請(qǐng)一個(gè)結(jié)構(gòu)體空間,并將地址強(qiáng)制轉(zhuǎn)換為結(jié)構(gòu)體指針變量賦值給p3