XLua框架搭建——lua性能分析

xlua代码里提供了一个性能分析的文档,里面提供了两个工具,一个是《函数调用时长分析工具》,一个是《内存泄漏定位工具》。

关于这两个工具建议自己扩展,尤其是内存工具这块,扩展后可以做两个快照的比对,快速定位到哪个函数出现了问题。

首先说下第一个工具,第一个工具用来分析时长,官方说明如下

api很简单,就三个,start和stop都是无参数,也很好理解,分别是统计开始以及结束。在start以及stop之间可以多次调用report(也可以考虑不调stop)。每次report会得到从start到调用report为止的函数时长统计报告(以字符串返回)。report函数只有一个可选参数,可以指明按照总时间(参数是字符串的”TOTAL”,这个是默认值),平均每次调用时间(“AVERAGE”),以及调用次数(“CALLED”)来排序。

在统计数据里有一个总时长和占统计时间的百分比,在我们计算真正代码执行时长时,应该是当前函数执行时长除以占统计时间的百分比,最后得到的数据才是我们统计的代码执行时间。
在对这个进行扩展时主要是进行一些排序扩展以及对c函数,执行时长为0的函数进行过滤,以便更好的进行分析。

第二个工具,内存泄漏定位,一般来说我们可以在平时使用OnGUI实时监视当前内存数据

api就两个,total获取lua虚拟机的内存占用,单位是Kbytes,以lua number返回。而snapshot返回当前内存快照信息
如何定位内存泄漏:通过memory.total检测出内存的持续增长,然后通过memory.snapshot定位出哪里泄漏(lua测的内存泄漏都是表现为往某table添加了数据忘了删除)。

 GUI.Label(new Rect(10, Screen.height - 40, 200, 20), "Lua Memory:" + LuaEnv.Memroy + "Kb");

在对界面多次打开关闭并执行gc回收后内存有明显增加的时候,这个工具就派上用场了,尤其是在扩展快照比对的工具中,我们能快速定位到哪一个变量的内存变化了,变化了多少等。

QQ交流群:517539056,欢迎大家加入一起交流

你可能感兴趣的:(Lua学习)