美文网首页Unity探路营
【专栏精选】热更新之xLua

【专栏精选】热更新之xLua

作者: 洪智 | 来源:发表于2019-04-29 18:41 被阅读0次

    本文节选自洪流学堂公众号技术专栏《大话Unity2019》,未经允许不可转载。

    洪流学堂公众号回复专栏,查看更多专栏文章。


    洪流学堂,让你快人几步。你好,我是郑洪智。

    xLua

    小新:“之前你提到过,Unity热更新有两大流派,C#派和lua派,那lua派是啥样的呢?”
    大智:“lua是一门历史悠久的脚本语言,从端游那个年代就被广泛应用在游戏开发中,所以到了现在的手游时代,有很多团队也让lua技术再次发展了起来。”

    Lua语言

    Lua 是一个小巧的脚本语言。是巴西里约热内卢天主教大学(Pontifical Catholic University of Rio de Janeiro)里的一个研究小组,由Roberto Ierusalimschy、Waldemar Celes 和 Luiz Henrique de Figueiredo所组成并于1993年开发。

    Lua设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。Lua由标准C编写而成,几乎在所有操作系统和平台上都可以编译运行。Lua并没有提供强大的库,因为它的定位就是作为嵌入的脚本语言,所以Lua不适合开发独立应用程序。Lua有一个同时进行的JIT项目,提供在特定平台上的即时编译功能。

    Lua脚本可以很容易的被C/C++代码调用,也可以反过来调用C/C++的函数,这使得Lua在应用程序中可以被广泛应用,特别是在端游阶段,游戏几乎都是使用C/C++开发的,lua给游戏开发带来了极大的便利性。

    不仅仅作为扩展脚本,lua也可以作为普通的配置文件,代替XML、JSON、ini等文件格式,并且很容易理解和维护。Lua由标准C编写而成,代码简洁优美,几乎在所有操作系统和平台上都可以编译运行。一个完整的Lua解释器不过200k,在目前所有脚本引擎中,Lua的速度是最快的。这一切都决定了Lua是作为嵌入式脚本的最佳选择。

    很多我们熟悉的游戏中都使用了Lua脚本,比如魔兽世界、大话西游2、仙剑奇侠传、古剑奇谭等。

    Lua之所以在游戏开发中这么受欢迎,也是因为它的优点:(1)语言优美、轻巧 (2)性能优良、速度快 (3)可扩展性强。

    Unity与Lua

    Unity中的Lua也一直在发展,目前Unity中比较流行的几个Lua框架有:

    其中xLua是腾讯团队开发维护的一个框架,广泛应用在腾迅系的手游中,也是目前最受认可以及使用比较多的一个框架。

    相对于我们之前学过的ILRuntime呢,lua也有一些优势和弱势。
    Lua的优势:

    • 技术更为成熟
    • 成功的商业案例更多

    Lua的劣势:

    • 需要开发团队掌握Lua
    • 可能需要维护C#和lua两套代码

    后面我们会以目前最为主流的xLua来进行学习。

    xLua

    xLua为Unity、 .Net、 Mono等C#环境增加Lua脚本编程的能力,借助xLua,这些Lua代码可以方便的和C#相互调用。

    xLua的突破
    xLua在功能、性能、易用性都有不少突破,这几方面分别最具代表性的是:

    • 可以运行时把C#实现(方法,操作符,属性,事件等等)替换成lua实现,也就是热补丁功能;
    • 出色的GC优化,自定义struct,枚举在Lua和C#间传递无C# gc alloc;
    • 编辑器下无需生成代码,开发更轻量;

    下载

    下载地址为:https://github.com/Tencent/xLua/releases

    可以选择最新的zip下载:


    上面图中可以看到xLua有几个不同的版本,有什么区别呢?

    xLua有两个版本,分别集成了lua5.3和luajit,一个项目只能选择其一。这两个版本C#代码是一样的,不同的是Plugins部分。

    • xlua:此版本集成的是lua5.3,lua5.3的特性更丰富些,比如支持原生64位整数,支持苹果bitcode,支持utf8等。出现问题因为是纯c代码,也好定位。比起luajit,lua对安装包的影响也更小。
    • xlua_luajit:此版本集成的是luajit,luajit胜在性能,如果其jit不出问题的话,可以比lua高一个数量级。目前luajit作者不打算维护luajit,在找人接替其维护,后续发展不太明朗。
    • xlua_general:用于通用的.Net或Mono环境,可以在非Unity环境中使用。

    目前lua53版本使用较多,所以xLua工程Plugins目录下默认配套是lua53版本,我们后面学习中也会使用这个版本。

    安装

    安装非常简单,新建一个Unity工程。

    打开zip包,你会看到一个Assets目录,这目录就对应Unity工程的Assets目录,保持这目录结构放到你的Unity工程。

    拖到空白处覆盖现在的Assets目录

    如果你遇到了报错:
    error CS0246: The type or namespace name 'ILGenerator' could not be found (are you missing a using directive or an assembly reference?)

    可以查阅xLua的FAQ文档https://github.com/Tencent/xLua/blob/master/Assets/XLua/Doc/faq.md

    在这我也把这个问题的解决方法贴过来:

    ILGenerator报错
    这是因为Api Compatibility Level设置为.net standard 2.0,而.net standard 2.0不支持emit导致的。

    解决办法(三选一):

    • 把“Scripting Backend”设置为3.5
    • 把Api Compatibility Level设置为.Net 4.x
    • 更新xLua到2019年1月8号后面的版本,可以解决编译问题,但由于没有emit的支持,编辑器下要生成代码才能跑了,建议执行“XLua/Generate Minimize Code”,这个少生成些代码。

    在这我选择了第二种把Api Compatibility Level设置为.Net 4.x,来暂时解决这个问题。

    把Api Compatibility Level设置为.Net 4.x

    改成这个造成的可能的影响是:影响程序最终打包的体积,因为这个选项会包含所有的.Net 4兼容的API。

    修改后我们的工程里就不报错了。

    总结

    大智:“今天我们了解了Lua以及xLua的使用前的准备。”

    今日思考题

    大智:“在你的电脑上建立一个xLua的工程,为我们明天做准备哦”
    小新:“好嘞!”
    大智:“收获别忘了分享出来!也别忘了分享给你学Unity的朋友,也许能够帮到他。”


    洪流学堂公众号回复专栏,查看更多专栏文章。

    《大话Unity2019》,大智带小新学Unity2019的有趣经历,让你学Unity更简单。

    相关文章

      网友评论

        本文标题:【专栏精选】热更新之xLua

        本文链接:https://www.haomeiwen.com/subject/qeyunqtx.html