1. 開啟動態連結程式庫:
#include <dlfcn.h>
void *dlopen(const char *filename, int flag);
該函數返回操作控制代碼,如:
void *pHandle = dlopen(strSoFilePath, RTLD_LAZY);
2. 取動態對象地址:
#include <dlfcn.h>
void *dlsym(void *pHandle, char *symbol);
dlsym根據動態連結程式庫操作控制代碼(pHandle)與符號(symbol),返回符號對應的地址。
使用這個函數不但可以擷取函數地址,也可以擷取變數地址。比如,假設在so中
定義了一個void mytest()函數,那在使用so時先聲明一個函數指標:
void (*pMytest)(),然後使用dlsym函數將函數指標pMytest指向mytest函數,
pMytest = (void (*)())dlsym(pHandle, "mytest");
3. 關閉動態連結程式庫:
#include <dlfcn.h>
int dlclose(void *handle);
該函數將該.so的引用計數減一,當引用計數為0時,將它從系統中卸載。
4. 動態庫錯誤函數:
#include <dlfcn.h>
const char *dlerror(void);
當動態連結程式庫操作函數執行失敗時,dlerror可以返回出錯資訊,傳回值為NULL時
表示沒有錯誤資訊。
在取到函數執行地址後,就可以在動態庫的使用程式雷根據動態庫提供的函數介面
調用動態庫裡的函數。
在編寫調用動態庫的程式的Makefile檔案時,需要加入編譯選項-ldl。
從void *dlsym(void *handle, char *symbol); 的參數可以看出,該函數只傳兩個
參數:一個指向so的handle和一個函數的symbol,所以so裡面的函數應該不允許重載,
否則根據一個 symbol不能確定指向那個函數。