什么是热更新?
简单来说,就是在用户通下载安装APP之后,打开App时遇到的即时更新。
热更新问题的本质是代码更新而不是资源更新,大型手游都是将补丁资源放在专门的WEB服务器上,游戏启动时动态下载并放入到游戏的持久化目录中,这对安卓和苹果都可以,但是代码就特殊了。
由于不同类型的语言有不同的运行机制,编译型语言如C#,是先编译成一整块中间码然后在不同平台上被.NET运行时解释执行,这就是说使用C#编写的APK或IPA安装到手机上后是没有任何C#文件的。这样就算运行时将作为补丁的C#文件从WEB服务器上下载到持久化目录也运行不了。
为什么需要热更新?
1,手游是快节奏的应用,功能和资源更新频繁,特别是重度手游安装包常常接近1个G,如果不热更新,哪怕改动一行代码也要重新打个包上传到网上让玩家下载。
2,对于IOS版本的手游包IPA,要上传到苹果商店进行审核,周期漫长,这对于BUG修复类操作是个灾难。
基于以上两点,热更新就很重要了,快速,小巧,路过苹果审核。
2、如何才能热更新?
3、Lua为什么能热更新?
LUA是解释型语言,也叫动态语言,好处是定义变量时不需要定义类型,代价是,动态语言不提供静态语言提供的类型安全特性,也因此lua并不需要事先编译成块,而是运行时动态解释执行的。
因为没有从编译代码到执行代码的中间过程,用动态语言编写应用程序可以快速看到输出。
二,C#为什么不能热更新
准确的说,C#在安卓上可以实现热更新,但在苹果上却不能。
在安卓上可以通过C#的语言特性-反射机制实现动态代码加载从而实现热更新。
具体做法是:将需要频繁更改的逻辑部分独立出来做成DLL,在主模块调用这些DLL,主模块代码是不修改的,只有作为业务(逻辑)模块的DLL部分需要修改。游戏运行时通过反射机制加载这些DLL就实现了热更新。
但苹果对反射机制有限制,不能实现这样的热更。为什么限制反射机制?安全起见,不能给程序太强的能力,因为反制机制实在太过强大,会给系统带来安全隐患。