第十天2017/04/21(1、函数指针、❤动态库回调❤)
生活随笔
收集整理的這篇文章主要介紹了
第十天2017/04/21(1、函数指针、❤动态库回调❤)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1、函數指針的語法基礎
【函數指針的定義、初始化、使用】對函數名去多少個&,都不起作用,都是一樣的,都還是它本身test。如:test、&test、&&test、&&&test都表示函數的入口地址 同樣:對函數名去多少個*,都不起作用,都是一樣的,都還是它本身test。如:test、*test、**test、***test都表示函數的入口地址 /* 定義函數指針:有兩種方法 1.方法一 ① C語言中通過typedef為函數類型重命名:typedef 返回類型 FUNC(形參列表);typedef void FUNC(int ,int ); //先給函數重命名為FUNC ② 用FUNC定義一個FUNC類型的函數指針pointerFUNC *pointer; //再用FUNC定義一個FUNC類型的函數指針pointer 2.方法二void (*pointer)(int ,int); //直接定義一個函數指針pointer */#include <iostream> using namespace std;typedef void FUNC(int); //給“參數是int,返回類型是int”的函數重命名為FUNC void test(int i) {cout<<"test()"<<endl; } int main() {FUNC *pointer = NULL; //1.用FUNC定義一個函數指針pointerpointer = &test; //2.用test函數的入口地址初始化函數指針pointer //等價于pointer = test;(*pointer)(100); //3.此處表示函數調用,其中*pointer表示函數名return 0; } 【同志們,注意了:重點來了】 一個函數的形參、實參如下:形參:(已經初始化的)函數指針實參:函數指針 可以在這個函數中,通過實參傳遞給形參,進而找到形參指向的函數的入口地址,就可以調用形參指向的函數了====>總結為:一個函數的形參為函數指針,可以調用該函數指針指向的函數。下面的程序案例只是簡單的講解用法,沒有什么實際意義,程序案例見下: #include <iostream> using namespace std;int add(int a,int b) {return a+b; }void gg(int (*p)(int,int),int a,int b) //函數指針作函數參數 {//在這個函數里面,可以通過這個函數指針,調用外部的函數,形成一個回調cout<<(*p)(a,b)<<endl; //在被調函數中,使用傳入的函數指針 } int main() {int (*p)(int,int); //定義一個函數指針p = &add; //初始化函數指針gg(p,1,2); //函數指針作形參 } ================================================================================== 【講解】正常情況下,我們都是去調用動態庫的代碼,但是有一天,動態庫的代碼要調用我們寫的代碼,這樣就形成了回調! 加載動態庫的兩種方式: 1.靜態調用:編譯器幫我們加載 2.動態調用:自己手工的加載HINSTANCE hDll;//定義一個句柄hDll=LoadLibrary("F:\\DLL.dll");//1.動態加載DLL模塊句柄:加載動態庫if(hDll) //如果加載成功{//2.定義一個函數指針,去接受獲得的GetProcAddress函數返回的函數的入口地址typedef int (*pAdd)(int,int) = NULL; //定義一個函數指針類型pAddpAdd ptr = (pAdd)GetProcAddress(hDll,"add");;//用函數指針類型pAdd,去定義一個函數指針變量ptrif(ptr){int result=ptr(2,3);printf("%d",result); }FreeLibrary(hDll);//釋放已經加載的DLL模塊}—————————————————————————————————————————-
【動態庫回調函數的實現的兩種方式】
總結
以上是生活随笔為你收集整理的第十天2017/04/21(1、函数指针、❤动态库回调❤)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第九天2017/04/18(4、非虚继承
- 下一篇: 第十天2017/04/21(2、泛型编程