欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Lua和C/C++互相調(diào)用實(shí)例分析

 更新時(shí)間:2019年01月17日 10:19:26   作者:修語講編程  
今天小編就為大家分享一篇關(guān)于Lua和C/C++互相調(diào)用實(shí)例分析,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧

lua作為小巧精悍的腳本語言,易于嵌入c/c++中 , 廣泛應(yīng)用于游戲AI ,實(shí)際上在任何經(jīng)常變化的邏輯上都可以使用lua實(shí)現(xiàn),配合c/c++實(shí)現(xiàn)的底層接口服務(wù),能夠大大降低系統(tǒng)的維護(hù)成本。下面對lua和c/c++的交互調(diào)用做一個(gè)實(shí)例分析:

lua提供了API用于在c/c++中構(gòu)造lua的運(yùn)行環(huán)境,相關(guān)接口如下:

//創(chuàng)建lua運(yùn)行上下文
lua_State*
luaL_newstate(void) ;
//加載lua腳本文件
int luaL_loadfile(lua_State *L, const
char *filename);

lua和c/c++的數(shù)據(jù)交互通過”棧”進(jìn)行

,操作數(shù)據(jù)時(shí),首先將數(shù)據(jù)拷貝到”棧”上,然后獲取數(shù)據(jù),棧中的每個(gè)數(shù)據(jù)通過索引值進(jìn)行定位,索引值為正時(shí)表示相對于棧底的偏移索引,索引值為負(fù)時(shí)表示相對于棧頂?shù)钠扑饕饕狄?或-1為起始值,因此棧頂索引值永遠(yuǎn)為-1,棧底索引值永遠(yuǎn)為1 。 “棧”相當(dāng)于數(shù)據(jù)在lua和c/c++之間的中轉(zhuǎn)地。每種數(shù)據(jù)都有相應(yīng)的存取接口 。

數(shù)據(jù)入”棧”接口:

void (lua_pushnil) (lua_State *L);
void (lua_pushnumber) (lua_State *L, lua_Number n);
void (lua_pushinteger) (lua_State *L, lua_Integer n);
void (lua_pushlstring) (lua_State *L, const char *s, size_t l);
void (lua_pushstring) (lua_State *L, const char *s);
void (lua_pushboolean) (lua_State *L, int b);
void (lua_pushcclosure) (lua_State *L, lua_CFunction fn, int n);

數(shù)據(jù)獲取接口:

lua_Number (lua_tonumber) (lua_State *L, int idx);
lua_Integer (lua_tointeger) (lua_State *L, int idx);
int (lua_toboolean) (lua_State *L, int idx);
const char *(lua_tolstring) (lua_State *L, int idx, size_t *len);
lua_CFunction (lua_tocfunction) (lua_State *L, int idx);

“棧”操作接口:

int (lua_gettop) (lua_State *L);
void (lua_settop) (lua_State *L, int idx);
void (lua_pushvalue) (lua_State *L, int idx);
void (lua_remove) (lua_State *L, int idx);
void (lua_insert) (lua_State *L, int idx);
void (lua_replace) (lua_State *L, int idx);
int (lua_checkstack) (lua_State *L, int sz);

lua中定義的變量和函數(shù)存放在一個(gè)全局table中,索引值為LUA_GLOBALSINDEX,table相關(guān)操作接口:

void (lua_gettable) (lua_State *L, int idx);
void (lua_getfield) (lua_State *L, int idx, const char *k);
void (lua_settable) (lua_State *L, int idx);
void (lua_setfield) (lua_State *L, int idx, const char *k);

當(dāng)”棧”中包含執(zhí)行腳本需要的所有要素(函數(shù)名和參數(shù))后,調(diào)用lua_pcall執(zhí)行腳本:

int (lua_pcall) (lua_State *L, int nargs, int nresults, int errfunc);

下面進(jìn)行實(shí)例說明:

func.lua

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <errno.h>
//lua頭文件
#include <lua.h>
#include <lualib.h>
#include <lauxlib.h>
#define err_exit(num,fmt,args) \
  do{printf("[%s:%d]"fmt"\n",__FILE__,__LINE__,##args);exit(num);} while(0)
#define err_return(num,fmt,args) \
  do{printf("[%s:%d]"fmt"\n",__FILE__,__LINE__,##args);return(num);} while(0)
//lua中調(diào)用的c函數(shù)定義,實(shí)現(xiàn)加法
int csum(lua_State* l)
{
  int a = lua_tointeger(l,1) ;
  int b = lua_tointeger(l,2) ;
  lua_pushinteger(l,a+b) ;
  return 1 ;
}
int main(int argc,char** argv)
{
  lua_State * l = luaL_newstate() ;    //創(chuàng)建lua運(yùn)行環(huán)境
  if ( l == NULL ) err_return(-1,"luaL_newstat() failed");
  int ret = 0 ;
  ret = luaL_loadfile(l,"func.lua") ;   //加載lua腳本文件
  if ( ret != 0 ) err_return(-1,"luaL_loadfile failed") ;
  ret = lua_pcall(l,0,0,0) ;
  if ( ret != 0 ) err_return(-1,"lua_pcall failed:%s",lua_tostring(l,-1)) ;
  lua_getglobal(l,"width");       //獲取lua中定義的變量
  lua_getglobal(l,"height");
  printf("height:%ld width:%ld\n",lua_tointeger(l,-1),lua_tointeger(l,-2)) ;
  lua_pop(l,1) ;            //恢復(fù)lua的棧
  int a = 11 ;
  int b = 12 ;
  lua_getglobal(l,"sum");        //調(diào)用lua中的函數(shù)sum
  lua_pushinteger(l,a) ;
  lua_pushinteger(l,b) ;
  ret = lua_pcall(l,2,1,0) ;
  if ( ret != 0 ) err_return(-1,"lua_pcall failed:%s",lua_tostring(l,-1)) ;
  printf("sum:%d + %d = %ld\n",a,b,lua_tointeger(l,-1)) ;
  lua_pop(l,1) ;
  const char str1[] = "hello" ;
  const char str2[] = "world" ;
  lua_getglobal(l,"mystrcat");     //調(diào)用lua中的函數(shù)mystrcat
  lua_pushstring(l,str1) ;
  lua_pushstring(l,str2) ;
  ret = lua_pcall(l,2,1,0) ;
  if ( ret != 0 ) err_return(-1,"lua_pcall failed:%s",lua_tostring(l,-1)) ;
  printf("mystrcat:%s%s = %s\n",str1,str2,lua_tostring(l,-1)) ;
  lua_pop(l,1) ;
  lua_pushcfunction(l,csum) ;     //注冊在lua中使用的c函數(shù)
  lua_setglobal(l,"csum") ;      //綁定到lua中的名字csum
  lua_getglobal(l,"mysum");      //調(diào)用lua中的mysum函數(shù),該函數(shù)調(diào)用本程序中定義的csum函數(shù)實(shí)現(xiàn)加法
  lua_pushinteger(l,a) ;
  lua_pushinteger(l,b) ;
  ret = lua_pcall(l,2,1,0) ;
  if ( ret != 0 ) err_return(-1,"lua_pcall failed:%s",lua_tostring(l,-1)) ;
  printf("mysum:%d + %d = %ld\n",a,b,lua_tointeger(l,-1)) ;
  lua_pop(l,1) ;
  lua_close(l) ;           //釋放lua運(yùn)行環(huán)境
  return 0 ;
}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接

相關(guān)文章

  • C++基礎(chǔ)入門教程(一):基礎(chǔ)知識大雜燴

    C++基礎(chǔ)入門教程(一):基礎(chǔ)知識大雜燴

    這篇文章主要介紹了C++基礎(chǔ)入門教程(一):基礎(chǔ)知識大雜燴,本文講解了注釋、頭文件、命名空間等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • 詳解C語言中的Static關(guān)鍵字

    詳解C語言中的Static關(guān)鍵字

    這篇文章主要為大家介紹了C語言中Static關(guān)鍵字,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • C語言動(dòng)態(tài)內(nèi)存分配的詳解

    C語言動(dòng)態(tài)內(nèi)存分配的詳解

    這篇文章主要介紹了C語言動(dòng)態(tài)內(nèi)存分配的詳解的相關(guān)資料,這里提供了實(shí)現(xiàn)方法整理和出現(xiàn)錯(cuò)誤的解決辦法,需要的朋友可以參考下
    2017-07-07
  • C++實(shí)現(xiàn)簡單的HTTP服務(wù)器

    C++實(shí)現(xiàn)簡單的HTTP服務(wù)器

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡單的HTTP服務(wù)器的相關(guān)資料,感興趣的朋友可以參考下
    2016-05-05
  • c語言實(shí)現(xiàn)單鏈表算法示例分享

    c語言實(shí)現(xiàn)單鏈表算法示例分享

    這篇文章主要介紹了c語言實(shí)現(xiàn)單鏈表算法示例,需要的朋友可以參考下
    2014-02-02
  • 淺談C#中List<T>對象的深度拷貝問題

    淺談C#中List<T>對象的深度拷貝問題

    下面小編就為大家?guī)硪黄獪\談C#中List<T>對象的深度拷貝問題。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-01-01
  • Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解

    Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解

    對于瀏覽器的使用,我想大家一定不會陌生吧,輸入要搜索的內(nèi)容時(shí),會出現(xiàn)相應(yīng)的匹配信息。本文就來用Qt實(shí)現(xiàn)模糊匹配功能,感興趣的可以了解一下
    2022-10-10
  • C語言實(shí)現(xiàn)快速排序的方法及優(yōu)化

    C語言實(shí)現(xiàn)快速排序的方法及優(yōu)化

    這篇文章主要介紹了C語言實(shí)現(xiàn)快速排序的方法及優(yōu)化,快速排序是Hoare于1962年提出的一種二叉樹結(jié)構(gòu)的交換排序方法,下面我們來看一看傳說中的快速排序的特點(diǎn)與效率怎么樣,需要的朋友可以參考下
    2023-07-07
  • C++11 上下文關(guān)鍵字的具體實(shí)踐

    C++11 上下文關(guān)鍵字的具體實(shí)踐

    本文主要介紹了C++11 上下文關(guān)鍵字的具體實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C++ RTTI與4種類型轉(zhuǎn)換的深入理解

    C++ RTTI與4種類型轉(zhuǎn)換的深入理解

    這篇文章主要給大家介紹了關(guān)于C++ RTTI與4種類型轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論