C++中函數(shù)指針詳解及代碼分享
函數(shù)指針
函數(shù)存放在內(nèi)存的代碼區(qū)域內(nèi),它們同樣有地址。如果我們有一個int test(int a)的函數(shù),那么,它的地址就是函數(shù)的名字,如同數(shù)組的名字就是數(shù)組的起始地址。
1、函數(shù)指針的定義方式:data_types (*func_pointer)( data_types arg1, data_types arg2, ...,data_types argn);
c語言函數(shù)指針的定義形式:返回類型 (*函數(shù)指針名稱)(參數(shù)類型,參數(shù)類型,參數(shù)類型,…);
c++函數(shù)指針的定義形式:返回類型 (類名稱::*函數(shù)成員名稱)(參數(shù)類型,參數(shù)類型,參數(shù)類型,….);
例如: int (*fp)(int a); //這里就定義了一個指向函數(shù)(這個函數(shù)參數(shù)僅僅為一個int類型,函數(shù)返回值是int類型)的指針fp。
類成員函數(shù)指針與普通函數(shù)指針不是一碼事。前者要用.*與->*運(yùn)算符來使用,而后者可以用*運(yùn)算符(稱為“解引用”dereference,或稱“間址”indirection)。
普通函數(shù)指針實際上保存的是函數(shù)體的開始地址,因此也稱“代碼指針”,以區(qū)別于C/C++最常用的數(shù)據(jù)指針。
而類成員函數(shù)指針就不僅僅是類成員函數(shù)的內(nèi)存起始地址,還需要能解決因為C++的多重繼承、虛繼承而帶來的類實例地址的調(diào)整問題,所以類成員函數(shù)指針在調(diào)用的時候一定要傳入類實例對象。
函數(shù)指針示例
#include <stdio.h> #include <stdlib.h> int fun1() { printf("this is fun1 call\n"); return 1; } void fun2(int k, char c) { printf("this is fun2 call:%d %c\n", k, c); } int main() { int (*pfun1)() = NULL; void (*pfun2)(int, char) = NULL; int a,b; pfun1 = fun1; //第一種賦值方法 a = pfun1(); //第一種調(diào)用方法(推薦) printf("%d\n",a); b = (*pfun1)();//第二種調(diào)用方法 printf("%d\n",b); pfun2 = &fun2;//第二種賦值方法(推薦,因為和其他數(shù)據(jù)指針賦值方法一致) pfun2(1,'a'); (*pfun2)(2,'b'); return 0; }
函數(shù)指針作為函數(shù)參數(shù):
#include <stdio.h> #include <stdlib.h> void fun(int k, char c) { printf("this is fun2 call:%d %c\n", k, c); } void fun1(void (*pfun)(int, char), int a, char c) { pfun(a, c); } int main() { fun1(fun, 1, 'a'); return 0; } // c++ 的形式差不多
函數(shù)指針作為函數(shù)返回值:
// c 形式 #include <stdio.h> #include <stdlib.h> void fun(int k, char c) { printf("this is fun2 call:%d %c\n", k, c); } //fun1 函數(shù)的參數(shù)為double,返回值為函數(shù)指針void(*)(int, char) void (*fun1(double d))(int, char) { printf("%f\n",d); return fun; } int main() { void (*p)(int, char) = fun1(3.33); p(1, 'a'); return 0; } //c++ 形式 #include <iostream> using namespace std; class test { public: int fun(int a, char c) { cout<<"this is fun call:"<<a<<" "<<c<<endl; return a; } }; class test2 { public: // test2 的成員函數(shù)fun1,參數(shù)是double, //返回值是test的成員函數(shù)指針int(test::*)(int, char) int (test::*fun1(double d))(int, char) { cout<<d<<endl; return &test::fun; } }; int main() { test mytest; test2 mytest2; int (test::*p)(int, char) = mytest2.fun1(3.33); (mytest.*p)(1, 'a'); return 0; }
函數(shù)指針數(shù)組:
#include <stdio.h> #include <stdlib.h> float add(float a,float b){return a+b;} float minu(float a,float b){return a-b;} int main() { //定義一個函數(shù)指針數(shù)組,大小為2 //里面存放float (*)(float, float)類型的指針 float (*pfunArry[2])(float, float) = {&add, &minu}; double k = pfunArry[0](3.33,2.22);// 調(diào)用 printf("%f\n", k); k = pfunArry[1](3.33,2.22); printf("%f\n", k); return 0; } //c++ 可類比
typedef 簡化函數(shù)指針類型:
#include <stdio.h> #include <stdlib.h> float add(float a,float b) { printf("%f\n",a+b); return a+b; } float minu(float a,float b) { printf("%f\n",a-b); return a-b; } //用pfunType 來表示float(*)(float, float) typedef float(*pfunType)(float, float); int main() { pfunType p = &add;//定義函數(shù)指針變量 p(3.33, 2.22); pfunType parry[2] = {&add, &minu};//定義函數(shù)指針數(shù)組 parry[1](3.33, 2.22); //函數(shù)指針作為參數(shù)可以定義為:void fun(pfunType p) //函數(shù)指針作為返回值可以定義為:pfunType fun(); return 0; } //c++ 可類比
總結(jié)
以上就是本文關(guān)于C++中函數(shù)指針詳解及代碼示例的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:C語言實現(xiàn)的學(xué)生選課系統(tǒng)代碼分享等,有什么問題可以隨時留言,小編會及時回復(fù)大家的。
相關(guān)文章
C語言結(jié)構(gòu)體(struct)的詳細(xì)講解
C語言中,結(jié)構(gòu)體類型屬于一種構(gòu)造類型(其他的構(gòu)造類型還有:數(shù)組類型,聯(lián)合類型),下面這篇文章主要給大家介紹了關(guān)于C語言結(jié)構(gòu)體(struct)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03C++實現(xiàn)校園運(yùn)動會報名系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)校園運(yùn)動會報名系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-10-10通過stringstream實現(xiàn)常用的類型轉(zhuǎn)換實例代碼
在本篇文章里小編給大家分享了關(guān)于通過stringstream實現(xiàn)常用的類型轉(zhuǎn)換實例代碼內(nèi)容,需要的朋友們可以參考下。2020-04-04Qt數(shù)據(jù)庫應(yīng)用之實現(xiàn)數(shù)據(jù)圖文混排
除了能夠打印基本的文字信息數(shù)據(jù)到pdf和紙張,越來越多的應(yīng)用需求還要求能夠?qū)С鰣D片,并且要支持圖文混排。本文將通過Qt實現(xiàn)這一功能,需要的可以參考一下2022-01-01