您好,登錄后才能下訂單哦!
開始回調(diào)函數(shù)之前讓我們先簡單的介紹一下函數(shù)指針
假設(shè)有以下函數(shù)的聲明
int foo(int);
函數(shù)指針的定義:
int (*p)(int)=&foo;
以上的&符可以省略,編譯器會把函數(shù)名轉(zhuǎn)換為函數(shù)指針,加上&只是顯示的說明了編譯器將隱式執(zhí)行的任務(wù)
函數(shù)指針的使用:
(*p)(10);
p(10);
以上兩種均通過函數(shù)指針調(diào)用到foo函數(shù) ,月也可以通過直接使用函數(shù)名調(diào)用foo(10);
下面正式介紹回調(diào)函數(shù):
Callback最本質(zhì)的特征包括兩點:注冊和觸發(fā)
概念:回調(diào)函數(shù)就是你自己寫的一個函數(shù),你需要調(diào)用一個中間函數(shù)(可以是系統(tǒng)函數(shù)也可以是自己寫的)并傳遞一個函數(shù)指針給這個函數(shù),而恰好這個函數(shù)指針指向那個回調(diào)函數(shù),這樣,你可以在那個回調(diào)函數(shù)里完成一些事情。
一個簡單的例子:
int compare_char(void const *a,void const *b) { //do something } int compare_int(void const *a,void const *b) { //do something } Node *search_list(Node *node,void const *value,int (*compare)(void const *,void const*)) { while(node!=NULL){ if(0==compare(value,&node->_value)) break; node=node->_next; } return node; }
search_list(&node,&value,compare_int);
在這個例子里,回調(diào)函數(shù)比較兩個值,返回0表示相等,非0表示不相等,而查找函數(shù)與類型無關(guān),真正的比較由比較函數(shù)來完成
用分層的概念來解釋回調(diào)機制:main函數(shù)和比較函數(shù)屬于A層,search_list函數(shù)屬于B層,main函數(shù)調(diào)用了search_list,search_list又調(diào)用了比較函數(shù),search_list函數(shù)就相當(dāng)于一個接口。
必須是靜態(tài)成員函數(shù)或者全局函數(shù)來實現(xiàn)回調(diào)函數(shù)
大概原因是普通的C++成員函數(shù)都隱含了一個傳遞函數(shù)作為參數(shù),即this指針,C++通過傳遞this指針給成員函數(shù)從而實現(xiàn)函數(shù)可以訪問C++的數(shù)據(jù)成員。由于this指針的原因,使得一個普通成員函數(shù)作為回調(diào)函數(shù)時就會因為隱含的this指針問題使得函數(shù)參數(shù)個數(shù)不匹配,從而導(dǎo)致回調(diào)函數(shù)編譯失敗。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。