指向函數的指針。本質是一個指針。
指針變量可以指向變量的地址、數組、字符串、動態分配地址,同時也可指向一個函數,每個函數在編譯的時候,系統會分配給該函數一個入口地址,函數名表示這個入口地址,那麼指向函數的指針變量稱為函數指針變量。
引論: int sumup(int a, float b); int (*p3) (int a, float b); //加入p3=&sumup;則p3作為指針指向sumup。這就是p3指針指向函數 【回顧:兩者的返回值和形參都是 int (int a, float b);】 int* (*p4)(int a, float b); 從類型上看,int* (int a, float b) 是上式函數的指針。故有:p4 = &p3;
int (*p) (int x); // 聲明一個函數指針
//可以通過以下兩種方式將func函數的首地址賦給指針p
p=func;
p=&func;
取地址運算符&不是必需的,因為單單一個函數標識符就標號表示了它的地址,如果是函數調用,還必須包含一個圓括號括起來的參數表。可以采用如下兩種方式來通過指針調用函數:
x=(*p)();
x=p(); //雖然看起來和普通的調用無異,但是有些程序員傾向於使用第一種格式,因為它明確指出是通過指針而非函數名來調用函數的
如使用引論中的例子有如下的調用: sumup (100,1.21); (*p3) (100,1.21); //與上等價 *(p4) (100,1.21); //與上等價
示例程序:
void (*funcp)(); void FileFunc(),EditFunc(); main() { funcp=FileFunc; (*funcp)(); funcp=EditFunc; (*funcp)(); } void FileFunc() { printf(FileFunc\n); } void EditFunc() { printf(EditFunc\n); } 程序輸出為: FileFunc EditFunc
int * GetDate(int wk,int dy) //返回某元素的地址 { static int calendar[5][7]={ {1,2,3,4,5,6,7}, {8,9,10,11,12,13,14}, {15,16,17,18,19,20,21}, {22,23,24,25,26,27,28}, {29,30,31,-1} }; return &calendar[wk-1][dy-1]; } main() { int wk,dy; do { printf(Enter week(1-5)day(1-7)\n); scanf(%d%d,&wk,&dy); } while(wk<1 || wk>5 || dy<1 || dy>7); printf(%d\n,*GetDate(wk,dy)); }