C語言應(yīng)用程序中經(jīng)常使用動態(tài)鏈接機(jī)制集成各個模塊;不過,動態(tài)鏈接機(jī)制并不是ANSI C標(biāo)準(zhǔn)的一部分,也就是說實現(xiàn)方法是不可以移植的。
Lua通常不會包含任何無法通過ANSI C來實現(xiàn)的機(jī)制,如果動態(tài)鏈接是一個例外。Lua打破了對可移植性的準(zhǔn)則,為幾種平臺實現(xiàn)了一套動態(tài)鏈接機(jī)制。
package.loadlib是動態(tài)鏈接功能的核心函數(shù),接收兩個參數(shù):動態(tài)庫的完整路徑名、函數(shù)名稱。
loadlib函數(shù)加載指定的庫,并將其鏈接入Lua;如你所想,并不會調(diào)用庫中的任何函數(shù),而是將一個C函數(shù)作為Lua函數(shù)返回;如果load過程中發(fā)生任何錯誤,返回nil。
loadlib是一個比較底層的函數(shù),通常使用require來加載C程序庫,這個函數(shù)會搜索指定的程序庫,然后調(diào)用loadlib來加載庫,并返回初始化函數(shù),這個初始化函數(shù)應(yīng)將庫中提供的函數(shù)注冊到Lua中。
作為一個簡單的實例:
復(fù)制代碼 代碼如下:
hello.c
#includestdio.h>
void hello(){
printf("hello,world\n");
}
編譯:gcc -o libhello.so -fPIC -shared hello.c
復(fù)制代碼 代碼如下:
> f = package.loadlib('${pathhere}/libhello.so', 'hello')
> f()
hello,world
hello()函數(shù)比較簡單,沒有參數(shù),沒有返回值,具體的接口規(guī)范還需研究。