Xamarin开发的时候大家都有一个疑问,就是apk文件会不会特别的大,启动会不会很慢。答案是肯定的,文件肯定大,启动肯定会慢,但是具体大多少、具体慢多少,有什么因素可以使apk文件稍微小一点、可以使启动时间稍微短一点呢?
How to make a Xamarin.Forms app have smaller apk size and start up faster?
在Xamarin的编译选项中有几个比较关键,分别是:BundleAssemblies AotAssemblies EnableLLMV和 AndroidLinkMode
这三个选项的编辑页面只有在enterprise版本里有,但是如果你是community版本,依然可以通过修改csproj文件直接修改这些编译选项。
通过创建一个默认的Xamarin.Forms工程,修改各种编译选项,然后看它的编译的apk大小和启动时间,得出下表。这里启动时间是指从点击启动app到肉眼判断第一个页面完全显示。
Bundle |
AoT |
LLVM |
Link none |
Link sdk |
Link all |
Api size (M) |
Startup time (s) |
||
1 |
Y |
21 |
4.5 |
||||||
2 |
Y |
15 |
4.24 |
||||||
3 |
y |
y |
y |
24 |
4.2 |
||||
4 |
y |
y |
y |
y |
17 |
4.6 |
Link all 大小减少6M (2) |
||
5 |
y |
y |
y |
y |
22m |
4.7s |
Link sdk 大小减少10m (1) |
||
6 |
y |
y |
y |
y |
32 |
5.5s |
|||
7 |
Y |
Y |
y |
20 |
2.7 |
||||
8 |
y |
y |
y |
25.7 |
2.7 |
llvm加大启动时间2s (3) |
|||
9 |
Y |
Y |
27 |
2.5 |
AoT使apk大8M (4) 启动时间减少2s |
(1)比较6和5:link sdk可以使得apk大小减小10M。
(2)比较5和4:link all可以使得apk大小再减小6M。
(3)比较8和5:llvm会使apk大小减小3M,但启动时间增加了2s。
(4)比较9和2:AoT会使apk大小变大8M
综合结论:
AndroidLinkMode对apk大小有很大影响,link all时apk文件最小。对启动时间基本无影响。
EnableLLMV会使apk大小减小,但启动时间变长。
AotAssemblies 使apk大小变大。
AotAssemblies 使启动时间变短。(这个是间接得出的结论,因为启动时间变化的因素中:link mode无影响,LLVM使时间变长,Bundle基本无影响,那么使启动时间变短的只能是AotAssemblies )
BundleAssemblies 对文件大小、启动时间的影响较小。
结论:
apk大小和启动时间是互斥的。建议的选项配置:使用BundleAssemblies、AotAssemblies AndroidLinkMode(sdk & user,也就是all),不使用EnableLLMV。
同时可以得到,Xamarin.Froms程序,apk大小大约20M,启动时间2秒。
题外话:
这其实是Xamarin将c#编译为native code的一个应用,也可以把这个特性(BundleAssemblies, AotAssemblies)当做一个混淆代码的更佳方案。