日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

cocosc++怎么打印_Lua调用C++时打印堆栈信息

發(fā)布時(shí)間:2025/3/21 c/c++ 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 cocosc++怎么打印_Lua调用C++时打印堆栈信息 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

公司的手游項(xiàng)目,使用的是基于cocos2d-x綁lua的解決方案(參數(shù)quick-x的綁定),雖然使用了lua進(jìn)行開發(fā),更新很爽了,但是崩潰依然較為嚴(yán)重,從后臺查看崩潰日志時(shí),基本上只能靠“猜”來復(fù)現(xiàn)bug。更為郁悶的是很多時(shí)候并沒有使用log輸出,在崩潰日志里還無法查看大概在哪一步操作崩潰的…

后來在網(wǎng)上搜索了一下,受到一點(diǎn)啟發(fā),lua代碼在執(zhí)行的時(shí)候可隨時(shí)調(diào)用debug.traceback()方法來獲得調(diào)用棧的字符串信息,如下圖所示:

而c++導(dǎo)出方法給lua調(diào)用,是使用tolua++工具實(shí)現(xiàn)的,通過ant實(shí)現(xiàn)將多個(gè)pkg文件生成一個(gè)cpp文件。所以只能在ant的build.xml配置中想辦法了,好在ant本身就支持正則的任務(wù)“ReplaceRegExp”,在調(diào)用的方法前面添加打印堆棧的方法即可。

打印lua調(diào)用堆棧的方法:

// 打印lua調(diào)用棧開始

lua_getglobal(tolua_S, "debug");

lua_getfield(tolua_S, -1, "traceback");

int iError = lua_pcall( tolua_S,//VMachine

0,//Argument Count

1,//Return Value Count

0);

const char* sz = lua_tostring(tolua_S, -1);

CCLog(sz);

Ant腳本build.xml添加一項(xiàng)任務(wù):

match="^\s+self->([^;]+);$" replace='lua_getglobal(tolua_S, "debug"); lua_getfield(tolua_S, -1, "traceback"); int iError = lua_pcall(tolua_S, 0, 1, 0); const char* sz = lua_tostring(tolua_S, -1); CCLOG(sz); self->\1;'

byline="true"

flags="g"/>

注: 為換行符

參數(shù)資源:

總結(jié)

以上是生活随笔為你收集整理的cocosc++怎么打印_Lua调用C++时打印堆栈信息的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。