iOS - Bitcode App 瘦身中间码

1、Bitcode

  • 随着 Xcode7 的发布,Apple 提供了一项新的技术来支持 App 瘦身功能,那就是 Bitcode。
  • 1、BitCode 是什么
    • Bitcode is an intermediate representation of a compiled program. Apps you upload to iTunes Connect that contain bitcode will be compiled and linked on the store. Including bitcode will allow Apple to re-optimize your app binary in the future without the need to submit a new version of your app to the store.
    • Xcode hides symbols generated during build time by default, so they are not readable by Apple. Only if you choose to include symbols when uploading your app to iTunes Connect would the symbols be sent to Apple. You must include symbols to receive crash reports from Apple.
    • 上述引自Apple的文档 App Thinning (iOS, tvOS, watchOS)
    • 其大概意思是 Bitcode 类似于一个中间码,被上传到 AppleStore 之后,苹果会根据下载应用的用户的手机指令集类型生成只有该指令集的二进制,进行下发,从而达到精简安装包体积的目的。

  • 2、一点编译原理
    • 为了更好的理解什么是 Bitcode,我们简短的看一下编译器编译的过程:

      • Lexer :读入源文件,并将其转化成字符流。
      • Parser :将字符流转换成 AST(抽象语法树)。
      • Semantic Analysis :对输入的 AST 进行语法检查。
      • Code Generation :代码生成,将 AST 转换成低层次的IR指令。
      • Optimization :分析 IR 指令,将其中潜在会拖慢运行速度的指令干掉。
      • AsmPrinter :通过 IR(中间码)生成特定 CPU 架构的汇编代码。
      • Assemble :将汇编代码转化成二进制。
      • Linker :通常程序会引用其他的二进制文件(.a 或者 framework),但是这些链接在程序中没有正确的地址,只是个占位符。Linker 的工作就是给这些占位符正确的地址。
      • 更多信息可以参考:The Compiler
    • 一般情况下,在真实的编译器构架那种,会将上述过程分成前端和后端两部分来处理:

      • 在前后端之间传递的就是 IR(中间码),而 Bitcode 就是一种特殊形式的中间码。原本前后端的工作都是在本地 LLVM 中完成,虽然 Apple 没有给出具体的 Bitcode 实现,但是通过他们的文档可以猜测,是将一部分后端的工作移到了服务器进行。从 Xcode 上传 IR 到服务器,服务器来真对不同的机型进行后续操作。从而达到真对不同机型生成对应指令集的二进制,而减小包体积的目的。
  • 3、Bitcode 设置
    • 实际上在 Xcode7 + 中,我们新建一个 iOS 程序时,Bitcode 选项默认是设置为 YES 的。我们可以在 Build Settings => Build Options => Enable Bitcode 选项中看到这个设置。
    • 不过,我们现在需要考虑的是三个平台:iOS / Mac OS / watchOS。
      • 对应 iOS,Bitcode 是可选的。
      • 对于 watchOS,Bitcode 是必须的。
      • Mac OS 不支持 Bitcode。
    • 如果我们开启了 Bitcode,在提交包时,下面这个界面也会有个 Bitcode 选项:

      • 但是如果其中包含第三方库,不支持 Bitcode 时候,需要将 Enable BitCode 设置成 NO。而且这个选项是只要有一个第三方库不支持,就不能开的,否则连接错误。
    • 确保打包的时候使用的是 fembed-bitcode, 而不是 fembed-bitcode-maker
      • You should be aware that a normal build with the -fembed-bitcode-marker option will produce minimal size embedded bitcode sections without any real content. This is done as a way of testing the bitcode-related aspects of your build without slowing down the build process. The actual bitcode content is included when you do an Archive build.
      • fembed-bitcode-maker:只是简单的标记一下在 archive 出来的二进制中 Bitcdoe 所在的位置。
      • fembed-bitcode:真的会生成 Bitcode 指令,并且嵌入到二进制中,这个设置不止要在 app 中设置,同样你也必须在编译静态链接库的时候使用。而且需要主题的是该参数系统只默认在 archive 模式下会添加。
    • 需要注意的是 Bitcode 只默认在 archive 下编译。在 debug 和 release 下并不会。
      • 如果您开发的是 app 那么走正常的打包 archive 流程就好了。如果你正在开发 .a 静态库或者 framework,请注意打包方式设置为 archive,或者在打包脚本中加入 -fembed-bitcode 参数。如果需要的话,需要在 Build Settings 中打开 DEPLOYMENT_POSTPROCESSING=YES,设置 Strip Style 为 debugging。
  • 4、检测是否打开 Bitcode
    • 当打开 Bitcdoe 选项之后,我们可以使用 otool 工具来检查二进制文件中是否包含 bitcode 段。
    • 针对于静态链接库 .a 文件
          otool -arch armv7 -l xxxx.a | grep __bitcode | wc -l
      • 如果是当前库支持 .a 文件则会输出一个数字,如果不支持 Bitcode 则不会出现该数字。

      • 上述命令只检查了 armv7 架构,同时,也必须使用该指令检查其他的指令集是否包含 Bitcode 如:arm64,armv7s 等等
    • 检查 app 或者 framework 中是否包含 Bitcode
      • 由于 app 中二进制和 framework 中二进制文件与 .a 文件存在差异,因为需要检查的是 __LLVM 段,当出现该段的时候,则表示支持 Bitcdoe,否则不支持。

            otool -l xxxx | grep __LLVM | wc -l
      • 这里 otool 有个 bug,当你的 framework 使用过 lipo 命令,进行拆解和合并之后,需要指定指令集进行检查才可以。
            otool -arch armv7 -l xxxx | grep __LLVM | wc -l
      • BUT, 上述检查过了之后,也不一定是真的支持 Bitcode,在实际的测试中,发现上述检测命令通过之后,某个使用的第三方库,依然报错不支持 Bitcode。因而最终结果,还是需要以是否能够连接成功为准。重要事情说三遍,上述网上流传的检测方法只做参考,最终还是要以实际效果为准。
    • 最终结果检查
      • 如果您是一个 APP,可以直接进行 Archive 打包,如果是一个库,则建议建一个 Demo 工程进行打包,记得要打开 Bitcode 设置。
      • CheckPoint1 连接是否报错
        • 如果有任何一个库没有打开 Bitcode 链接,将会出现类似下方的错误。只要链接过了,那么恭喜了,基本上是 OK 了。

      • CheckPoint2 检查最终效果
        • 使用开发模式导出 ipa

  • 5、选择出包的方式
    • 这里建议使用第二种,生成针对具体机型的包

      • 出现了,Compiling Bitcode,这个过程

    • 在最后输出的文件中,你能够看到一个 App Thinning 的结果,里面有针对各个机型的 ipa 包。

    • 在 App Thinning Size Report 中能够明显看到,由于使用了 Bitcode 等技术之后,所带来的收益:
          App Thinning Size Report for All Variants of Black
          Variant: Black-iPad (4th generation)-etc.ipa
          Supported devices: iPad (3rd generation) and iPad (4th generation)
          App + On Demand Resources size: 368 KB compressed, 737 KB uncompressed
          App size: 368 KB compressed, 737 KB uncompressed
          On Demand Resources size: Zero KB compressed, Zero KB uncompressed
          ....
时间: 2024-10-24 23:42:38

iOS - Bitcode App 瘦身中间码的相关文章

致Android开发者:APP 瘦身经验总结

随着移动端产品功能的逐渐增加,APP 的体积也不可避免地呈现上升趋势,如果不加以重视,几个版本迭代下来,可能你的 APP 体积会达到用户不能忍受的程度. 如果你是 SDK 开发者,你的 SDK 包大小是用户决定是否采用的关键因素:如果你的APP 想要预装到某款手机或者某款 Android 系统中,APP 的体积也会受到很严格的限制. 因此,APP 的瘦身是每个移动端产品都会遇到的一个普遍问题,本文选自<Android高级进阶>将从不同的角度切入,全面介绍APP 瘦身相关知识. APP 为什么变

Android App瘦身实战

随着业务的快速迭代增长,不断引入新的业务逻辑代码.图片资源和第三方SDK等,很多app都面临一个一个结果,app越来越大,甚至很多无用的代码,包体积的增大带来了很多问题,诸如app启动更慢,代码维护越来越困难.公司业务发展到一定程度之后,重构,代码优化,app瘦身成为不得不做的一个任务.这里以xx外卖app为例给大家讲讲app瘦身过程中常用的几种方法(也都是网上老生常谈的). apk文件构成 我们可以用Zip工具打开APK,一个常见的APK结构如下: 可以看到APK由以下主要部分组成: 文件/目

Android APP瘦身(清除工程中没用到的资源)详解_Android

清除Android工程中没用到的资源 项目需求一改再改,UI一调再调,结果就是项目中一堆已经用不到但却没有清理的垃圾资源,不说工程大小问题,对新进入项目的人或看其他模块的代码的人来说,这些没清理的资源可能也可能会带来困扰,所以最好还是清理掉这些垃圾,对于一个稍微大一点的工程来说,手工清理明显是不现实的,这就需要一个方法做这些事情. 清理资源文件 要清理没用的资源,首要的工作当然是找到他们,我们知道Anroid SDK中有一个工具叫lint,可以帮助我们查看工程中存在的问题,其中有一项功能就是查找

Android APP瘦身(清除工程中没用到的资源)详解

清除Android工程中没用到的资源 项目需求一改再改,UI一调再调,结果就是项目中一堆已经用不到但却没有清理的垃圾资源,不说工程大小问题,对新进入项目的人或看其他模块的代码的人来说,这些没清理的资源可能也可能会带来困扰,所以最好还是清理掉这些垃圾,对于一个稍微大一点的工程来说,手工清理明显是不现实的,这就需要一个方法做这些事情. 清理资源文件 要清理没用的资源,首要的工作当然是找到他们,我们知道Anroid SDK中有一个工具叫lint,可以帮助我们查看工程中存在的问题,其中有一项功能就是查找

APP加固新方向--混淆和瘦身

近些年来移动APP数量呈现爆炸式的增长,黑产也从原来的PC端转移到了移动端,造成数据泄漏.源码被盗.APP被山寨.破解后注入病毒或广告现象让用户和生产高质量的程序员苦不堪言,APP加固意义愈发重大. 传统加固和脱壳技术的发展经过了三代的发展和升级,时至今日,传统加固面临到挑战,如容易被脱壳,脱壳类教程非常多,通用脱壳机可轻易脱大部分壳. 加固新方向,混淆和瘦身吸引了人们的眼球.代码混淆技术是对抗逆向攻击最有效的方式之一.此外越来越多的新特性正在啃蚀着大型APP的用户体验,APP瘦身减肥也成了亟待

【直播】APP全量混淆和瘦身技术揭秘

[直播]APP全量混淆和瘦身技术揭秘 近些年来移动APP数量呈现爆炸式的增长,黑产也从原来的PC端转移到了移动端,通过逆向手段造成数据泄漏.源码被盗.APP被山寨.破解后注入病毒或广告现象让用户苦不堪言.  为了解决安卓APP容易被逆向的问题,除了对产品进行加固处理,代码混淆技术是对抗逆向攻击最有效的方式之一.本直播会分享阿里聚安全带来的APP全量混淆技术.此外越来越多的新特性正在啃蚀着大型APP的用户体验,APP瘦身减肥也成了亟待解决的问题,如何能在使用安全功能同时瘦身,也将是本期主题所带来的

iOS9系列专题三——应用瘦身

更小,更快--iOS9的App Thinning         apple在iOS9中引入了一套新的app瘦身方案,通过一些优化策略,将尽可能的减小app安装包的体积.这部分的大多工作是由app store来完成,开发者并不需要付出太多额外的开销.这篇博客将这部分内容做了简单的介绍,详细信息在App Thinning.         App的瘦身策略主要包括三部分: 一.slicing         这部分的主要原理是不同的设备下载安装不同的app包,各个app包副本中包含相应尺寸的素材.

iOS App 安装包瘦身指南

以下列出了安装包瘦身的无脑执行流程,其中"奇技淫巧"部分为选做题 资源优化 删除无用图片 使用LSUnusedResources查找无用图片 删除重复资源 压缩图片资源 使用ImageOptim无损压缩图片 使用TinyPNG有损压缩图片 TinyPNG非常好用强烈推荐 使用的时候直接执行 tinypng *.png -k token 脚本即可 奇技淫巧 用LaunchScreen.storyboard替换启动图片 本地大图片都使用webp 资源按需加载,非必要资源都等到使用时再从服务

iOS9 App Thinning(应用瘦身)功能介绍

iOS9 发布后,产生了一个使 App Thinning 无法正常运行的 bug.在iOS9.0.2 版本中,这个 bug 已经被修复,App Thinning 已经可以正常使用.当你从应用商店(App Store)下载应用时,请注意这点. iOS9 推出之后,大受欢迎.仅仅数周,已经有超过半数的 iOS 设备安装了这一新系统.这是 iOS 历代版本中采纳速度最快的-甚至打破了 2013 年 iOS7 创下的记录. 关于 iOS9,笔者最近发表了一篇名为Search APIs and SFSaf