簡明的C++函數(shù)指針學(xué)習(xí)教程
定義
每一個函數(shù)都占用一段內(nèi)存單元,它們有一個起始地址,指向函數(shù)入口地址的指針稱為函數(shù)指針。
語法
數(shù)據(jù)類型 (*指針變量名)(參數(shù)表):
int (*myFunc)(double b, int c);
說明
函數(shù)指針的定義形式中的數(shù)據(jù)類型是指函數(shù)的返回值的類型。
區(qū)分下面兩個語句:
int (*p)(int a, int b);//p是一個指向函數(shù)的指針變量,所指函數(shù)的返回值類型為整型 int *p(int a, int b);//p是函數(shù)名,此函數(shù)的返回值類型為整型指針
指向函數(shù)的指針變量不是固定指向哪一個函數(shù)的,而只是表示定義了一個這樣類型的變量,它是專門用來存放函數(shù)的入口地址的;在程序中把哪一個函數(shù)的地址賦給它,它就指向哪一個函數(shù)。
在給函數(shù)指針變量賦值時,只需給出函數(shù)名,而不必給出參數(shù)。
如函數(shù)max的原型為:int max(int x, int y); 指針p的定義為:int (*p)(int a, int b); 則p = max;的作用是將函數(shù)max的入口地址賦給指針變量p。這時,p就是指向函數(shù)max的指針變量,也就是p和max都指向函數(shù)的開頭。
在一個程序中,指針變量p可以先后指向不同的函數(shù),但一個函數(shù)不能賦給一個不一致的函數(shù)指針(即不能讓一個函數(shù)指針指向與其類型不一致的函數(shù))。
如有如下的函數(shù):
int fn1(int x, int y); int fn2(int x);
定義如下的函數(shù)指針:
int (*p1)(int a, int b); int (*p2)(int a);
則
p1 = fn1; //正確 p2 = fn2; //正確 p1 = fn2; //產(chǎn)生編譯錯誤
定義了一個函數(shù)指針并讓它指向了一個函數(shù)后,對函數(shù)的調(diào)用可以通過函數(shù)名調(diào)用,也可以通過函數(shù)指針調(diào)用(即用指向函數(shù)的指針變量調(diào)用)。
如語句:c = (*p)(a, b); //表示調(diào)用由p指向的函數(shù)(max),實參為a,b,函數(shù)調(diào)用結(jié)束后得到的函數(shù)值賦給c。
函數(shù)指針只能指向函數(shù)的入口處,而不可能指向函數(shù)中間的某一條指令。不能用*(p+1)來表示函數(shù)的下一條指令。
函數(shù)指針變量常用的用途之一是把指針作為參數(shù)傳遞到其他函數(shù)。
函數(shù)指針使用舉例
說明看代碼注釋就可以
#include <iostream> using namespace std; class test { public: test() { cout<<"constructor"<<endl; } int fun1(int a, char c) { cout<<"this is fun1 call:"<<a<<" "<<c<<endl; return a; } void fun2(double d)const { cout<<"this is fun2 call:"<<d<<endl; } static double fun3(char buf[]) { cout<<"this is fun3 call:"<<buf<<endl; return 3.14; } }; int main() { // 類的靜態(tài)成員函數(shù)指針和c的指針的用法相同 double (*pstatic)(char buf[]) = NULL;//不需要加類名 pstatic = test::fun3; //可以不加取地址符號 pstatic("myclaa"); pstatic = &test::fun3; (*pstatic)("xyz"); //普通成員函數(shù) int (test::*pfun)(int, char) = NULL; //一定要加類名 pfun = &test::fun1; //一定要加取地址符號 test mytest; (mytest.*pfun)(1, 'a'); //調(diào)用是一定要加類的對象名和*符號 //const 函數(shù)(基本普通成員函數(shù)相同) void (test::*pconst)(double)const = NULL; //一定要加const pconst = &test::fun2; test mytest2; (mytest2.*pconst)(3.33); // //構(gòu)造函數(shù)或者析構(gòu)函數(shù)的指針,貌似不可以,不知道c++標(biāo)準(zhǔn)有沒有規(guī)定不能有指向這兩者的函數(shù)指針 // (test::*pcon)() = NULL; // pcon = &test.test; // test mytest3; // (mytest3.*pcon)(); return 0; }
相關(guān)文章
C++ Boost MetaStateMachine定義狀態(tài)機(jī)超詳細(xì)講解
Boost是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進(jìn)程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴(kuò)展的一些C++程序庫的總稱2022-12-12舉例講解C語言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法
fork函數(shù)是Linux下一個近乎專有的C語言函數(shù),因為使用時需要調(diào)用unistd.h這個頭文件,這里我們就在Linux環(huán)境下舉例講解C語言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法,需要的朋友可以參考下2016-06-06C++實現(xiàn)LeetCode(141.單鏈表中的環(huán))
這篇文章主要介紹了C++實現(xiàn)LeetCode(141.單鏈表中的環(huán)),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07