UE4 Unlua源码解析9 - 静态绑定和动态绑定的实现原理
Posted 珞珈大胖强TURBO
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了UE4 Unlua源码解析9 - 静态绑定和动态绑定的实现原理相关的知识,希望对你有一定的参考价值。
静态绑定和动态绑定的实现原理
先说明白什么是静态绑定,什么是动态绑定
静态绑定就是继承了UnluaInterface的类,会在对象创建的时候绑定Lua对象
动态绑定就是没有继承UnluaInterface的类,会在Lua端通过"NewObject"和"SpawnActor"创建的时候,主动进行绑定
静态绑定
UE对象和Lua对象的时机在什么时候呢?就在UE对象刚刚创建的时候
可以看到FLuaContext继承了FUObjectCreateListener
实现了这两个方法,这两个方法调用的时机就是Uobject创建时
几个重要函数总结
逐行详解在前文
Manager->Bind
创建出Lua对象LuaInstance,然后设置各种信息,然后把Lua对象和C++对象的映射保存了起来,C++存在AttachedObjects中,Lua存在ObjectMap中,对Lua对象,push一个Initialize方法进去并执行
结束后类图
2 BindInternal
总结:Bind的重要实现函数,还是实现Lua绑定UObject
1 Lua模块名和C++对象的UClass记录在ModuleNames、Classes表中
2 如果Lua模块的方法中,有和C++函数同名的方法,则直接拿这个C++函数的反射信息进行改写,改写为执行Lua方法
3 NewLuaObject
总结: 创建Lua表对应UObject
4 PushObjectCore
总结:PushObjectCore函数就是在lua栈中创建了一个userdata,然后将它的值设为一个指向UObject指针的指针,它的元表设为RegisterClass时创建的、类型对应的元表
此时Lua对象被创建出来,上文留的问题假如返回值是一个UObject的对象呢,怎么转换成Lua
其实就是在PostCall的实现中,最后调用PushUObject
PushUObject中,具体做法是:根据返回值UObject的指针,去Lua栈中的ObjectMap中取出Lua对象放入栈顶,这样代码执行完后,Lua那边收到的就是一个Lua对象了,这Lua对象就是
动态绑定
SpawnActor最终调用到UWorld_SpawnActor
看下Binging的生成,最终会调到Push,把一些静态绑定的信息添加进去
这样在UObject创建完之后,之前的流程中就会有ModuleName信息,也可以根据静态绑定的代码继续绑定。
以上是关于UE4 Unlua源码解析9 - 静态绑定和动态绑定的实现原理的主要内容,如果未能解决你的问题,请参考以下文章
UE4 Unlua源码解析9 - 静态绑定和动态绑定的实现原理
UE4 Unlua源码解析5 - FLuaContext内重要方法逐行解释
UE4 Unlua源码解析5 - FLuaContext内重要方法逐行解释
UE4 Unlua源码解析11 - 非UE4反射支持的静态类导出给Lua使用原理