彻底解决IL2CPP 开启Strip Engine Code选项后带来的崩溃问题

131 篇文章 3 订阅
9 篇文章 2 订阅

 

IL2CPP根据C#生成的Cpp代码行数巨大,达到百万行级别,进而引起iOS平台可执行文件超过60MB的问题。因此在适当的时候有必要对UnityEngine下的代码进行Strip。但是这样做容易带来如下的问题:
ReportException: UnityLogError Could not produce class with ID XXX.
This could be caused by a class being stripped from the build even though it is needed.
Try disabling 'Strip Engine Code' in Player Settings.
其中XXX代表被Strip掉但是资源所需要的YAML ClassID.

之所以会出现这样的问题,目前的猜测是Unity进行Code Strip时,只分析一下几个方面所用到的类:

    C#代码:Assembly-CSharp.dll、firstpass.dll、各插件Dll.
    Resources资源:BuildSettings里面的场景引用的资源和Resources文件夹下面的资源
    link.xml:Assets文件夹下面开发者可创建一个link.xml作为Code Strip白名单。另外观察Jenkins打包日志可以发现Unity安装目录下playbackEngines文件夹内含Unity自己的一套link.xml白名单

这样来看上述Crash发生的原因就比较明确了,那些打入AssetBundle的文件使用了Unity的其他类,但是同时在以上三个分析范围之外,Unity会将其Strip掉;当从AssetBundle进行加载时,由于缺少对应的类造成Deserialize失败,进而引起崩溃。

了解以上原因后,解决方案就呼之欲出了。只需要得到资源所用到的所有Unity引擎类,将其加入至link.xml即可。

    UnityEngine.Dll: 一般的做法是获取所有Prefab、场景文件中的组件进行汇总,这里说一个更简单的办法,直接观察Unity YAML的结构,很容易就能发现以下格式指明了Unity引擎类的ID:
    --- !u!XXX
    其中XXX代表YAML ClassID,去Unity Manual上查表即可得到对应的类名。
    UnityEngine.UI.Dll:没有YAML ClassID可查,只能加载出Prefab时Get一下Component来判断,可能遗漏的情况是ScriptableObject中对其进行了引用。
    UnityEditor.Dll:一个很特殊的情况,如果AssetBundle里使用到了AniamtorController,那么就需要UnityEditor下面的AnimatorController相关的几个类(还有AnimationState、Transition之类),直接添加进link.xml显然没什么意义。解决方案也很简单,在Resources下面增加一个空的AnimatorController,让Unity自己处理。

值得注意的是,这一块Unity自己的Bug也不少,出现奇怪的问题不妨先去issueTracker和Fix List看看 :)

PS: IL2CPP相关的实现其实就在Unity的安装目录下,包含完整的从分析到生成C++、编译的逻辑,有兴趣可以逆向Dll看一下。
---------------------
作者:逝水追风
来源:CSDN
原文:https://blog.csdn.net/zhangdi2017/article/details/79168180
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值