C++函數(shù)指針和回調(diào)函數(shù)使用解析
函數(shù)指針
函數(shù)指針是指向函數(shù)的指針變量。
通常我們說(shuō)的指針變量是指向一個(gè)整型變、字符型或數(shù)組等變量,而函數(shù)指針是指向函數(shù)。
函數(shù)指針可以像一般函數(shù)一樣,用于調(diào)用函數(shù)、傳遞參數(shù)。
函數(shù)指針變量的聲明:
typedef int (*fun_ptr)(int,int); // 聲明一個(gè)指向同樣參數(shù)、返回值的函數(shù)指針變量
實(shí)例
以下實(shí)例聲明了函數(shù)指針變量 p,指向函數(shù) max:
#include <stdio.h>
int max(int x, int y){
return x > y ? x : y;
}
int main(void){
/* p 是函數(shù)指針 */
int (* p)(int, int) = & max; // &可以省略
int a, b, c, d;
printf("請(qǐng)輸入三個(gè)數(shù)字:");
scanf("%d %d %d", & a, & b, & c); /* 與直接調(diào)用函數(shù)等價(jià),d = max(max(a, b), c) */
d = p(p(a, b), c);
printf("最大的數(shù)字是: %d\n", d);
return 0;
}
#include <stdio.h>
int max(int x, int y){
return x > y ? x : y;
}
int main(void){
/* p 是函數(shù)指針 */
int (* p)(int, int) = & max; // &可以省略
int a, b, c, d;
printf("請(qǐng)輸入三個(gè)數(shù)字:");
scanf("%d %d %d", & a, & b, & c); /* 與直接調(diào)用函數(shù)等價(jià),d = max(max(a, b), c) */
d = p(p(a, b), c);
printf("最大的數(shù)字是: %d\n", d);
return 0;
}
編譯執(zhí)行,輸出結(jié)果如下:
請(qǐng)輸入三個(gè)數(shù)字:1 2 3
最大的數(shù)字是: 3
回調(diào)函數(shù)
函數(shù)指針作為某個(gè)函數(shù)的參數(shù)
函數(shù)指針變量可以作為某個(gè)函數(shù)的參數(shù)來(lái)使用的,回調(diào)函數(shù)就是一個(gè)通過(guò)函數(shù)指針調(diào)用的函數(shù)。
簡(jiǎn)單講:回調(diào)函數(shù)是由別人的函數(shù)執(zhí)行時(shí)調(diào)用你實(shí)現(xiàn)的函數(shù)。
你到一個(gè)商店買(mǎi)東西,剛好你要的東西沒(méi)有貨,于是你在店員那里留下了你的電話(huà),過(guò)了幾天店里有貨了,店員就打了你的電話(huà),然后你接到電話(huà)后就到店里去取了貨。在這個(gè)例子里,你的電話(huà)號(hào)碼就叫回調(diào)函數(shù),你把電話(huà)留給店員就叫登記回調(diào)函數(shù),店里后來(lái)有貨了叫做觸發(fā)了回調(diào)關(guān)聯(lián)的事件,店員給你打電話(huà)叫做調(diào)用回調(diào)函數(shù),你到店里去取貨叫做響應(yīng)回調(diào)事件。
實(shí)例
實(shí)例中 populate_array 函數(shù)定義了三個(gè)參數(shù),其中第三個(gè)參數(shù)是函數(shù)的指針,通過(guò)該函數(shù)來(lái)設(shè)置數(shù)組的值。
實(shí)例中我們定義了回調(diào)函數(shù) getNextRandomValue,它返回一個(gè)隨機(jī)值,它作為一個(gè)函數(shù)指針傳遞給 populate_array 函數(shù)。
populate_array 將調(diào)用 10 次回掉函數(shù),并將回掉函數(shù)的返回值賦值給數(shù)組。
#include <stdlib.h>
#include <stdio.h>
// 回調(diào)函數(shù)void populate_array(int *array, size_t arraySize, int (*getNextValue)(void)){
for (size_t i=0; i<arraySize; i++)
array[i] = getNextValue();
}
// 獲取隨機(jī)值
int getNextRandomValue(void){
return rand();
}
int main(void){
int myarray[10];
populate_array(myarray, 10, getNextRandomValue);
for(int i = 0; i < 10; i++) {
printf("%d ", myarray[i]);
}
printf("\n");
return 0;
}
編譯執(zhí)行,輸出結(jié)果如下:
1680728247524916226500739849436581144108930470211272101027544145785087814587779232007237709
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)與算法之排序總結(jié)(二)
這篇文章住要介紹的是選擇類(lèi)排序中的簡(jiǎn)單、樹(shù)形和堆排序,歸并排序、分配類(lèi)排序的基數(shù)排序,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2021-12-12
ON_COMMAND_RANGE多個(gè)按鈕響應(yīng)一個(gè)函數(shù)的解決方法
這篇文章主要介紹了ON_COMMAND_RANGE多個(gè)按鈕響應(yīng)一個(gè)函數(shù)的解決方法,需要的朋友可以參考下2014-07-07
C++98/11/17表達(dá)式類(lèi)別(小結(jié))
這篇文章主要介紹了C++98/11/17表達(dá)式類(lèi)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
C語(yǔ)言實(shí)現(xiàn)哈夫曼樹(shù)的方法
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)哈夫曼樹(shù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05
C語(yǔ)言實(shí)現(xiàn)循環(huán)鏈表
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)循環(huán)鏈表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07

