C++調用lua函數

C++ 調用Lua全局變量(普通)

	lua_getglobal(lua, "width");int width = lua_tointeger(lua,-1);lua_pop(lua,1);std::cout << width << std::endl;lua_close(lua);

這幾行代碼要放到lua_pcall(lua, 0,0,0);之后才可以.

C++給lua傳遞變量

	lua_pushstring(lua, "Hello");lua_setglobal(lua, "test");

這幾行要放到lua_pcall(lua, 0,0,0);之前,要不lua調不到test這個變量的值.

C++ 調用Lua全局變量表

	lua_getglobal(lua,"conf");lua_getfield(lua, -1, "titlename");std::cout << lua_tostring(lua,-1) << std::endl;lua_pop(lua, 1);lua_getfield(lua,-1,"height");std::cout << lua_tointeger(lua, -1) << std::endl;lua_pop(lua, 1);

C++給lua傳遞表

	/*C++給lua傳入普通表*/lua_newtable(lua);lua_pushstring(lua,"name");lua_pushstring(lua,"xiaoming");lua_settable(lua,-3);lua_pushstring(lua,"age");lua_pushinteger(lua,20);lua_settable(lua, -3);lua_setglobal(lua, "person");

C++ 調用lua函數

	/*C++ 調用 Lua函數 */lua_getglobal(lua, "event");/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/lua_pcall(lua, 0, 0, 0); 

lua

function event()print("C++ call lua")
end

優化:

	/*C++ 調用 Lua函數 */std::cout << "top is = " << lua_gettop(lua) << std::endl; //檢查堆棧是否有泄露lua_getglobal(lua, "event");/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/if (lua_pcall(lua, 0, 0, 0) != 0){	std::cout << "call event failed" << lua_tostring(lua, -1) << std::endl;lua_pop(lua,1);}std::cout << "top is = " << lua_gettop(lua) << std::endl;

C++ 調用lua函數,傳遞參數并接收返回值

	/*C++ 調用 Lua函數 */std::cout << "top is = " << lua_gettop(lua) << std::endl;lua_getglobal(lua, "event");lua_pushstring(lua,"key"); // 傳入參數/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/if (lua_pcall(lua, 1, 1, 0) != 0){	std::cout << "call event failed" << lua_tostring(lua, -1) << std::endl;lua_pop(lua,1);}else{std::cout << "lua return = " << lua_tostring(lua, -1) << std::endl;lua_pop(lua, 1);}std::cout << "top is = " << lua_gettop(lua) << std::endl;

lua?

function event(str)print("C++ call lua")print("str = " .. str)return "1234"
end

添加lua錯誤處理

	/*C++ 調用 Lua函數 */std::cout << "top is = " << lua_gettop(lua) << std::endl;int errfun = lua_gettop(lua);lua_getglobal(lua, "ferror");errfun++;lua_getglobal(lua, "event");lua_pushstring(lua,"key"); // 傳入參數	/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/if (lua_pcall(lua, 1, 1, errfun) != 0){	std::cout << "call event failed" << lua_tostring(lua, -1) << std::endl;lua_pop(lua,1);}else{std::cout << "lua return = " << lua_tostring(lua, -1) << std::endl;lua_pop(lua, 1);}lua_pop(lua, 1);std::cout << "top is = " << lua_gettop(lua) << std::endl;

Lua

function ferror(e)print("ferror = " .. e)return "lua change error"
endfunction event1(str)print("C++ call lua")print("str = " .. str)return "1234"
end

結果:

?

C++給lua傳表參數,C++接收表參數

	/*lua給C++傳入表*/lua_getglobal(lua,"conf");lua_getfield(lua, -1, "titlename");std::cout << lua_tostring(lua,-1) << std::endl;lua_pop(lua, 1);lua_getfield(lua,-1,"height");std::cout << lua_tointeger(lua, -1) << std::endl;lua_pop(lua, 1);/*C++ 調用 Lua函數 */std::cout << "top is = " << lua_gettop(lua) << std::endl;int errfun = lua_gettop(lua);lua_getglobal(lua, "ferror");errfun++;lua_getglobal(lua, "event");lua_pushstring(lua,"key"); // 傳入參數	lua_newtable(lua);lua_pushstring(lua,"name");lua_pushfstring(lua,"xiaoming");lua_settable(lua, -3);/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/if (lua_pcall(lua, 2, 1, errfun) != 0){	std::cout << "call event failed" << lua_tostring(lua, -1) << std::endl;lua_pop(lua,1);}else{lua_getfield(lua, -1,"id");std::cout << "lua return tab= " << lua_tointeger(lua, -1) << std::endl;lua_pop(lua, 1);}lua_pop(lua, 2);std::cout << "top is = " << lua_gettop(lua) << std::endl;

lua

function event(str,tab)print("C++ call lua")print("str = " .. str)print("tab = " .. tab.name)local re = {id=123}return re
end

全部代碼:

lua

--CTest()--CTestToString("lua string",123456,true)
--local arr = {"A001","A002","A003"};
--CTestArr(arr)
--local tab = {name="xiaoming",age="22",id="007"};
--CTestTable(tab)--local re = TestRe()
--print("re = " .. re)--local retab = TestReTable()
--print("name = " .. retab["name"])
--print("name = " .. retab["age"])width = 1920
print(test)conf = 
{titlename = "first lua",height = 1080
}print("person is name = " .. person["name"])
print("person is age = " .. person.age)function ferror(e)print("ferror = " .. e)return "lua change error"
endfunction event(str,tab)print("C++ call lua")print("str = " .. str)print("tab = " .. tab.name)local re = {id=123}return re
end

C++?

#include <iostream>
extern "C"
{
#include <lua.h>
#include <lualib.h>
#include <lauxlib.h>
}
#include <vector>
#include <string>
#include <map>int CTest(lua_State* L) // 返回值是固定的int類型,返回0表示沒有返回參數,返回1表示有一個返回參數
{std::cout << "int CTest" << std::endl;return 0;
}int CTestToString(lua_State* L)
{const char* luaStr = lua_tostring(L,1);std::cout << luaStr << std::endl;int num = lua_tointeger(L,2);std::cout << num << std::endl;bool is = lua_toboolean(L, 3);std::cout << is << std::endl;return 0;
}int CTestArr(lua_State* L)
{std::vector<std::string> vStr;std::cout << "int CTestArr" << std::endl;int arraySize = luaL_len(L, 1); //獲取表的大小for (int i = 1; i <= arraySize; ++i){lua_pushnumber(L,i);	//往棧中壓入一個數字,表示從數組中取那個下標的值,lua都是從1開始的所以i從1開始lua_gettable(L, 1);		//把上一行索引的位置出棧,再把i壓入 棧vStr.push_back(lua_tostring(L,-1));lua_pop(L,1);}for (auto& value : vStr){std::cout << value << std::endl;}return 0;
}int CTestTable(lua_State* L)
{std::cout << "int CTestTable" << std::endl;/*   讀取全部的表的內容 */std::map<std::string, std::string> mStr;lua_pushnil(L);while (lua_next(L, 1) != 0){mStr[lua_tostring(L, -2)] = lua_tostring(L,-1);lua_pop(L,1);}for (auto& value : mStr){std::cout << value.first << " = " << value.second << std::endl;}/* 只取一個lua_getfield(L,1,"name");std::cout << lua_tostring(L,-1) << std::endl;*/return 0;
}int TestRe(lua_State* L)
{lua_pushstring(L,"return value");return 1;
}int TestReTable(lua_State* L)
{lua_newtable(L);  // 創建一個表格,放在棧頂lua_pushstring(L,"name"); // 壓入keylua_pushstring(L,"ccname");//壓入valuelua_settable(L,-3); //彈出key value,并設置到表,表在棧頂了作為返回值lua_pushstring(L, "age"); // 壓入keylua_pushinteger(L, 21);//壓入valuelua_settable(L, -3); //彈出key value,并設置到表,表在棧頂了作為返回值return 1;
}int main()
{lua_State *lua = luaL_newstate();luaopen_base(lua);luaopen_string(lua);lua_register(lua,"CTest",CTest); //第一個參數是lua狀態指針,第二個參數是函數名稱,第三個參數是lua函數指針,第二個參數和第三個參數可以用不同的名字,但第三個必須使用正確的函數指針lua_register(lua, "CTestToString", CTestToString);lua_register(lua, "CTestArr", CTestArr);lua_register(lua, "CTestTable", CTestTable);lua_register(lua, "TestRe", TestRe);lua_register(lua, "TestReTable", TestReTable);/*C++給lua傳入普通值*/lua_pushstring(lua, "Hello");lua_setglobal(lua, "test");/*C++給lua傳入普通表*/lua_newtable(lua);lua_pushstring(lua,"name");lua_pushstring(lua,"xiaoming");lua_settable(lua,-3);lua_pushstring(lua,"age");lua_pushinteger(lua,20);lua_settable(lua, -3);lua_setglobal(lua, "person");luaL_loadfile(lua, "D:\\code\\MyCode\\C++\\Lua\\CPPAddLua\\testLua\\x64\\Debug\\main.lua");lua_pcall(lua, 0,0,0);/*lua給C++傳入普通值*/lua_getglobal(lua, "width");int width = lua_tointeger(lua,-1);lua_pop(lua,1);std::cout << width << std::endl;/*lua給C++傳入表*/lua_getglobal(lua,"conf");lua_getfield(lua, -1, "titlename");std::cout << lua_tostring(lua,-1) << std::endl;lua_pop(lua, 1);lua_getfield(lua,-1,"height");std::cout << lua_tointeger(lua, -1) << std::endl;lua_pop(lua, 1);/*C++ 調用 Lua函數 */std::cout << "top is = " << lua_gettop(lua) << std::endl;int errfun = lua_gettop(lua);lua_getglobal(lua, "ferror");errfun++;lua_getglobal(lua, "event");lua_pushstring(lua,"key"); // 傳入參數	lua_newtable(lua);lua_pushstring(lua,"name");lua_pushfstring(lua,"xiaoming");lua_settable(lua, -3);/*//第一個參數lua的狀態,第二個參數是傳遞給 Lua 函數的參數數量,第三個參數 Lua 函數中返回的結果數量,第四個參數這是錯誤處理函數在堆棧中的索引。如果在調用 Lua 函數時發生了錯誤,Lua 將調用此錯誤處理函數。如果不需要錯誤處理函數,可以將其設置為 0。*/if (lua_pcall(lua, 2, 1, errfun) != 0){	std::cout << "call event failed" << lua_tostring(lua, -1) << std::endl;lua_pop(lua,1);}else{lua_getfield(lua, -1,"id");std::cout << "lua return tab= " << lua_tointeger(lua, -1) << std::endl;lua_pop(lua, 1);}lua_pop(lua, 2);std::cout << "top is = " << lua_gettop(lua) << std::endl;lua_close(lua);getchar();return 0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/717822.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/717822.shtml
英文地址,請注明出處:http://en.pswp.cn/news/717822.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python 操作 Excel,如何又快又好?

?數據處理是 Python 的一大應用場景&#xff0c;而 Excel 則是最流行的數據處理軟件。因此用 Python 進行數據相關的工作時&#xff0c;難免要和 Excel 打交道。Python處理Excel 常用的系列庫有&#xff1a;xlrd、xlwt、xlutils、openpyxl ?xlrd &#xff0d; 用于讀取 Exce…

點云從入門到精通技術詳解100篇-基于點云網絡和 PSO 優化算法的手勢估計(續)

目錄 3 深度圖像處理及轉化 3.1 雙目深度攝像原理及深度圖的獲取 3.1.1 理想化雙目深度相機成像

day47_servlet

今日內容 0 復習昨日 1 接收請求 2 處理響應 0 復習昨日 HTTP請求中 請求行 請求方法,請求路徑 請求頭 頁面信息 請求正文 請求的數據 HTTP響應中 響應行 狀態碼 信息 響應頭 頁面信息 響應正文 要給瀏覽器的內容 1 接收請求 瀏覽器發出請求,經過web.xml映射匹配,找到Servlet…

STL容器之map和set

map和set ? c98支持的是單參數的隱式類型轉換&#xff0c;而c11支持多參數的隱式類型轉換&#xff1b; 1.map和set的使用 1.1set ? set實現key值不允許修改&#xff0c;是將iterator轉變成const_iterator&#xff1b;可以對同一個類型typedef成兩個不同的自定義標識符。即…

Rocky 9 安裝 R-CytoTRACE

官網給出的詳細指南&#xff0c;只是可能大家打不開或者懶得去看E文。 第一步&#xff0c;下載CytoTRACE安裝包。 wget https://cytotrace.stanford.edu/CytoTRACE_0.3.3.tar.gz 第二步&#xff0c;打開R或者Rstudio-server # 安裝依賴包 if (!requireNamespace("Bioc…

在vue中$nextTick 原理及作用

在vue中$nextTick 原理及作用 Vue 的 nextTick 其本質是對 JavaScript 執行原理 EventLoop 的一種應用。 nextTick 的核心是利用了如 Promise 、MutationObserver、setImmediate、setTimeout的原生 JavaScript 方法來模擬對應的微/宏任務的實現&#xff0c;本質是為了利用 Java…

每周AI新聞(2024年第9周)微軟與Mistral AI達成合作 | 谷歌發11B基礎世界模型 | 傳蘋果放棄電動汽車制造轉向生成式AI

這里是陌小北&#xff0c;一個正在研究硅基生命的碳基生命。正在努力成為寫代碼的里面背詩最多的&#xff0c;背詩的里面最會寫段子的&#xff0c;寫段子的里面代碼寫得最好的…廚子。 每周日解讀每周AI大事件。 大廠動向 【1】微軟與Mistral AI達成合作 微軟官宣與法國生成…

視頻云平臺——搭建SRS5平臺支持GB28181視頻流的推送

&#x1f4e2;歡迎點贊 &#xff1a;&#x1f44d; 收藏 ?留言 &#x1f4dd; 如有錯誤敬請指正&#xff0c;賜人玫瑰&#xff0c;手留余香&#xff01;&#x1f4e2;本文作者&#xff1a;由webmote 原創&#x1f4e2;作者格言&#xff1a;新的征程&#xff0c;我們面對的不僅…

謹用ArrayList中的subList方法

謹用ArrayList中的subList方法 規范一&#xff1a; ArrayList 的 subList 結果不可強轉成 ArrayList&#xff0c;否則會拋出 ClassCastException 異常&#xff1a; public static void test7() {List<Integer> list new ArrayList<>();list.add(1);list.add(2);…

JavaWeb—— SpringBootWeb綜合案例(登錄功能、登錄校驗、異常處理)

案例-登錄認證 目錄 案例-登錄認證1. 登錄功能1.1 需求1.2 接口文檔1.3 思路分析1.4 功能開發1.5 測試 2. 登錄校驗2.1 問題分析2.2 會話技術2.2.1 會話技術介紹2.2.2 會話跟蹤方案2.2.2.1 方案一 - Cookie2.2.2.2 方案二 - Session2.2.2.3 方案三 - 令牌技術 2.3 JWT令牌2.3.1…

程序員眼中的“祖傳代碼”

引言 在IT界&#xff0c;特別是在Java項目中&#xff0c;“祖傳代碼”通常指的是那些經過長時間積累、由多位開發者共同維護、且蘊含深厚技術沉淀的代碼片段或模塊。這些代碼可能存在于項目的核心模塊&#xff0c;也可能是一些輔助性的工具類。它們承載著項目的歷史&#xff0…

Matlab 多項式插值(曲線擬合)

文章目錄 一、簡介二、實現代碼三、實現效果參考資料一、簡介 由于對曲線擬合有些興趣,這里就找了一些資料從最基本的方法來看一下曲線擬合的效果: 二、實現代碼 % **********

Vue.js中的路由導航守衛和其使用方法

Vue.js 中的路由導航守衛是 Vue Router 提供的一套機制&#xff0c;用于在路由切換的過程中執行自定義代碼邏輯&#xff0c;包括但不限于權限驗證、頁面滾動位置保存、加載數據等。它分為三種類型&#xff1a; 全局前置守衛 (Global beforeEach Guard) 全局前置守衛應用在整個…

python科學計算庫之Numpy庫的使用的簡單習題

Numpy庫 Numpy&#xff08;Numerical Python的縮寫&#xff09;是一個開源的Python庫&#xff0c;用于進行科學計算。它提供了一個高性能的多維數組對象&#xff08;ndarray&#xff09;及用于處理這些數組的各種工具和函數。由于其高效和靈活的數據結構以及豐富的功能&#x…

Google 地圖 API 教程--干貨(1/2)

Google Maps API 教程 在本教程中我們將學習如何使用谷歌地圖API V3創建交互式地圖。 什么是 API? API = 應用程序編程接口(Application programming interface)。 API(Application Programming Interface,應用編程接口)其實就是操作系統留給應用程序的一個調用接口,…

【d34】【Java】【力扣】27. 移除元素

題目 給你一個數組 nums 和一個值 val&#xff0c;你需要 原地 移除所有數值等于 val 的元素&#xff0c;并返回移除后數組的新長度。 不要使用額外的數組空間&#xff0c;你必須僅使用 O(1) 額外空間并 原地 修改輸入數組。 元素的順序可以改變。你不需要考慮數組中超出新長…

案例介紹:汽車售后服務網絡構建與信息抽取技術應用(開源)

一、引言 在當今競爭激烈的汽車行業中&#xff0c;售后服務的質量已成為品牌成功的關鍵因素之一。作為一位經驗豐富的項目經理&#xff0c;我曾參與構建一個全面的汽車售后服務網絡&#xff0c;旨在為客戶提供無縫的維修、保養和配件更換服務。這個項目的核心目標是通過高效的…

spring、springmvc、springboot框架的介紹

前言 我們已經學過Spring&#xff0c;SpringMVC&#xff0c;SpringBoot了&#xff0c;那這三者之間有沒有聯系或者區別呢&#xff1f; spring是一個一站式的輕量級java開發的框架&#xff0c;那我們剛開始使用spring的時候&#xff0c;是需要配置很多的配置文件以及繁瑣的過程…

狀態機實現雙擊、短按、長按等按鍵識別檢測算法

1、按鍵識別算法的作用 按鍵識別算法在不同的技術和應用背景下有不同的作用&#xff0c;但其核心目標都是準確、可靠地檢測和區分用戶通過物理或虛擬按鍵所執行的操作。按鍵識別算法在各類電子設備及系統中起到至關重要的作用&#xff0c;它確保了人機交互的有效性和準確性&…

Vue前端+快速入門【詳解】

目錄 1.Vue概述 2. 快速入門 3. Vue指令 4.表格信息案例 5. 生命周期 1.Vue概述 1.MVVM思想 原始HTMLCSSJavaScript開發存在的問題&#xff1a;操作麻煩&#xff0c;耦合性強 為了實現html標簽與數據的解耦&#xff0c;前端開發中提供了MVVM思想&#xff1a;即Model-Vi…