函數存放在內存的代碼區(qū)域內,它們同樣有地址,我們如何能獲得函數的地址呢?
如果我們有一個int test(int a)的函數,那么,它的地址就是函數的名字,這一點如同數組一樣,數組的名字就是數組的起始地址。 定義一個指向函數的指針用如下的形式,以上面的test()為例: int (*fp)(int a);//這里就定義了一個指向函數的指針 函數指針不能絕對不能指向不同類型,或者是帶不同形參的函數,在定義函數指針的時候我們很容易犯如下的錯誤。 int *fp(int a);//這里是錯誤的,因為按照結合性和優(yōu)先級來看就是先和()結合,然后變成了一個返回整形指針的函數了,而不是函數指針,這一點尤其需要注意! 下面我們來看一個具體的例子: #include <iostream> #include <string> using namespace std; int test(int a); void main(int argc,char* argv[]) { cout<<test<<endl;//顯示函數地址 int (*fp)(int a); fp=test;//將函數test的地址賦給函數學指針fp cout<<fp(5)<<"|"<<(*fp)(10)<<endl; //上面的輸出fp(5),這是標準c++的寫法,(*fp)(10)這是兼容c語言的標準寫法,兩種同意,但注意區(qū)分,避免寫的程序產生移植性問題! cin.get(); } int test(int a) { return a; } typedef定義可以簡化函數指針的定義,在定義一個的時候感覺不出來,但定義多了就知道方便了,上面的代碼改寫成如下的形式: #include <iostream> #include <string> using namespace std; int test(int a); void main(int argc,char* argv[]) { cout<<test<<endl; typedef int (*fp)(int a);//注意,這里不是生命函數指針,而是定義一個函數指針的類型,這個類型是自己定義的,類型名為fp fp fpi;//這里利用自己定義的類型名fp定義了一個fpi的函數指針! fpi=test; cout<<fpi(5)<<"|"<<(*fpi)(10)<<endl; cin.get(); } int test(int a) { return a; }
|