-
Notifications
You must be signed in to change notification settings - Fork 428
内存分析
siney edited this page Jan 18, 2019
·
2 revisions
slua 支持运行时分析lua使用内存,可以查看内存分配细节,方便检查内存泄漏。
在unreal控制台输入slua.DumpUObjects,会在控制台里输出所有被lua引用的UOjbect对象,通过观察这些对象,你可以快速知道还有那些UObject被lua使用而无法回收,你需要根据情况去lua代码里置空来避免lua引用,从而被unreal回收。
在lua代码里也可以直接,调用slua.dumpUObjects函数来得到这些UObject的table返回值。
如果你想详细分析lua内存的使用情况,你可以开启Memory Profile,通过在控制台输入slua.StartMemoryTrack, 开启Memory Profile,默认是关闭的。
开启Memory Profile后,可以通过slua.DumpMemoryDetail控制台命令输出,从开启后到现在所有的未被内存使用信息,slua会报告内存分配的大小和具体位置,例如:
Cmd: slua.DumpMemoryDetail
Slua: Total memory alloc 1968
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:41
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:35
Slua: Memory alloc 640 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/Test.lua:36
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:41
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:7
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:8
Slua: Memory alloc 72 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:41
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:6
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:9
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:9
Slua: Memory alloc 512 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:9
Slua: Memory alloc 72 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:41
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:5
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestActor.lua:4
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:50
Slua: Memory alloc 56 from @C:/Users/siney/Desktop/workspace/sluaunreal/Content//Lua/TestMap.lua:35
通过这个Dump List,你可以分析那些内存尚未释放,占用多少内存,从而帮助你解决内存泄漏的问题。