亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++函數(shù)指針和回調函數(shù)使用解析

 更新時間:2018年10月25日 09:31:11   作者:KiddouXiaoyu  
這篇文章主要為大家詳細介紹了C++函數(shù)指針和回調函數(shù)的使用,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

函數(shù)指針

函數(shù)指針是指向函數(shù)的指針變量。

通常我們說的指針變量是指向一個整型變、字符型或數(shù)組等變量,而函數(shù)指針是指向函數(shù)。

函數(shù)指針可以像一般函數(shù)一樣,用于調用函數(shù)、傳遞參數(shù)。

函數(shù)指針變量的聲明:

typedef int (*fun_ptr)(int,int); // 聲明一個指向同樣參數(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("請輸入三個數(shù)字:"); 
scanf("%d %d %d", & a, & b, & c);  /* 與直接調用函數(shù)等價,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("請輸入三個數(shù)字:"); 
scanf("%d %d %d", & a, & b, & c);  /* 與直接調用函數(shù)等價,d = max(max(a, b), c) */ 
d = p(p(a, b), c);  
printf("最大的數(shù)字是: %d\n", d);  
return 0;
}

編譯執(zhí)行,輸出結果如下:

請輸入三個數(shù)字:1 2 3
最大的數(shù)字是: 3

回調函數(shù)

函數(shù)指針作為某個函數(shù)的參數(shù)

函數(shù)指針變量可以作為某個函數(shù)的參數(shù)來使用的,回調函數(shù)就是一個通過函數(shù)指針調用的函數(shù)。

簡單講:回調函數(shù)是由別人的函數(shù)執(zhí)行時調用你實現(xiàn)的函數(shù)。

你到一個商店買東西,剛好你要的東西沒有貨,于是你在店員那里留下了你的電話,過了幾天店里有貨了,店員就打了你的電話,然后你接到電話后就到店里去取了貨。在這個例子里,你的電話號碼就叫回調函數(shù),你把電話留給店員就叫登記回調函數(shù),店里后來有貨了叫做觸發(fā)了回調關聯(lián)的事件,店員給你打電話叫做調用回調函數(shù),你到店里去取貨叫做響應回調事件。

實例

實例中 populate_array 函數(shù)定義了三個參數(shù),其中第三個參數(shù)是函數(shù)的指針,通過該函數(shù)來設置數(shù)組的值。

實例中我們定義了回調函數(shù) getNextRandomValue,它返回一個隨機值,它作為一個函數(shù)指針傳遞給 populate_array 函數(shù)。

populate_array 將調用 10 次回掉函數(shù),并將回掉函數(shù)的返回值賦值給數(shù)組。

#include <stdlib.h> 
 #include <stdio.h> 
// 回調函數(shù)void populate_array(int *array, size_t arraySize, int (*getNextValue)(void)){ 
for (size_t i=0; i<arraySize; i++)
  array[i] = getNextValue();
} 
// 獲取隨機值
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í)行,輸出結果如下:

1680728247524916226500739849436581144108930470211272101027544145785087814587779232007237709

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • VC基于ADO技術訪問數(shù)據(jù)庫的方法

    VC基于ADO技術訪問數(shù)據(jù)庫的方法

    這篇文章主要介紹了VC基于ADO技術訪問數(shù)據(jù)庫的方法,較為詳細的分析了VC使用ADO操作數(shù)據(jù)庫的相關實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • C語言中6組指針和自增運算符結合方式的運算順序問題

    C語言中6組指針和自增運算符結合方式的運算順序問題

    本文通過代碼實現(xiàn)分析了6種組合:* p++,(* p)++,* (p++),++* p,++( * p), * (++p),需要的朋友可以參考下
    2015-07-07
  • c語言 漢諾塔算法代碼

    c語言 漢諾塔算法代碼

    c語言 漢諾塔算法代碼,需要的朋友可以參考一下
    2013-04-04
  • C語言中結構體的內存對齊規(guī)則講解

    C語言中結構體的內存對齊規(guī)則講解

    C 數(shù)組允許定義可存儲相同類型數(shù)據(jù)項的變量,結構是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲不同類型的數(shù)據(jù)項,本篇讓我們來了解C 的結構體內存對齊
    2022-05-05
  • C++中的std::initializer_list使用解讀

    C++中的std::initializer_list使用解讀

    這篇文章主要介紹了C++中的std::initializer_list使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Qt數(shù)據(jù)庫應用之實現(xiàn)通用數(shù)據(jù)庫清理

    Qt數(shù)據(jù)庫應用之實現(xiàn)通用數(shù)據(jù)庫清理

    項目如果需要存儲很多日志記錄比如運行日志,時間長了記錄數(shù)量非常多,數(shù)據(jù)庫體積不斷增大,對應數(shù)據(jù)庫表的增刪改查的效率不斷降低,因此需要將早期的數(shù)據(jù)清理。本文將詳細介紹一下通用數(shù)據(jù)庫清理的實現(xiàn),需要的可以參考一下
    2022-02-02
  • 顯示內存狀態(tài)示例分享

    顯示內存狀態(tài)示例分享

    這篇文章主要介紹了顯示內存狀態(tài)示例,代碼簡單,下面直接看代碼,需要的朋友可以參考下
    2014-02-02
  • Cocos2d-x學習筆記之CCScene、CCLayer、CCSprite的默認坐標和默認錨點實驗

    Cocos2d-x學習筆記之CCScene、CCLayer、CCSprite的默認坐標和默認錨點實驗

    這篇文章主要介紹了Cocos2d-x學習筆記之CCScene、CCLayer、CCSprite的默認坐標和默認錨點實驗,這是一個非常值得研究的問題,需要的朋友可以參考下
    2014-09-09
  • 淺析c++函數(shù)參數(shù)和返回值

    淺析c++函數(shù)參數(shù)和返回值

    c++一直以來是一個關注效率的代碼,這樣關于函數(shù)的參數(shù)傳遞和返回值的接收,是重中之重,這篇文章主要介紹了c++函數(shù)參數(shù)和返回值,需要的朋友可以參考下
    2023-05-05
  • C語言歸排與計排深度理解

    C語言歸排與計排深度理解

    這篇文章主要為大家詳細的介紹了C語言中計數(shù)排序和歸并排序,歸并排序是創(chuàng)建在歸并操作上的一種有效的排序算法,計數(shù)排序不用比較兩個數(shù)的大小,感興趣的朋友可以參考閱讀
    2023-04-04

最新評論