程序员用5分钟,把一个400多MB的苹果安装包削掉了187MB

2022 年 2 月 26 日 量子位
丰色 发自 凹非寺
量子位 | 公众号 QbitAI

前些日子,一个手机QQ安装包就要快900MB的事儿在网上吵得沸沸扬扬。

 最新安装包又大了,已经924MB

虽然最后大家发现它主要为了视频通话特效多了一个虚幻引擎,但网友还是感叹:

现在的App真的是越来越大了。

而就在最近,国外一位程序员也遇到了同样的困惑。

他乘的一班飞机由于没有机上小电视,只能下载一个叫做“美联航”的App来看视频打发时间。

小哥一边感叹现在航空公司越来越鸡贼:把成本都加到顾客头上,一边打开了应用商店,结果就很诧异:

不就用来看个电影啥的吗,一个Netflix都只有101.5MB,这App怎么是它的四倍

作为一名iOS/Android开发工程师,小哥决定不“坐以待毙”,看看它是否真的需要这么大的空间。

原来可以省掉187MB

说干就干,还在飞机上的小哥立刻用ipatool下载了这个App的二进制文件。

ipatool是GitHub上标星1.4k的开源项目,是一个命令行工具,可以从iOS应用商店搜索和下载应用程序的ipa文件包,用这个包可以进行开发内容的一些检查等功能。

下好以后需要把ipa扩展名改为zip,解压之后可以看到下面这样的目录:

可以发现Frameworks就占了414.8MB,小哥解释:应用程序的主要内存来源就是Frameworks,现在的最佳实践都是把代码push到这里面,还是挺正常的。

接下来进入该目录:

以UAL开头的框架是核心架构、NodeMobile框架跟NodeJS功能有关、LocusLabsSDK和Mapbox是供应地图的,还有一些是负责身份验证、客户反馈的……

而视频播放相关的框架相反其实占内存并不多:

接着进入占空间最大的UALAppCore.framework。

经过层层探索,小哥终于在这里锁定了最大占存的UALAppCore。

按照他的工作经验,77MB这个数字还是有点反常的,他打算用nm命令深入看看这个框架的符号表(symbol)文件(nm用于显示二进制目标文件的符号表,格式如下)

很快他就想起来,Swift的符号需要剥离(strip,iOS框架中的术语),Objective-C则不需要。

那就查Swift的,结果还真就发现:

没有一个Swift框架的符号被剥离过。

而这些都没有用,白白耗内存:

那接下来就简单了,写一个bash脚本运行一下该框架就可以OK:

最后,可以看到原始框架从350MB减到了163M!

小哥表示,这一顿操作只花了不到5分钟,没想到可削减空间这么大,整整省掉了187MB。

等于现在的安装包只有原来的不到60%了

他猜测该安装包仍有削减空间,不过这个结果他已经很满意了。

你,学废了吗?

“开发商才不关心呢”

就在小哥发出这个博客之后,有网友评论道,还有很多安装包其实都可以再缩减15%到30%甚至更高的空间,就比如Gmail、Outlook这些很常见的应用。

但似乎现在很多开发商不是很关心这个问题,他们只想赶紧不停更新应用:

给不给用户省掉这几百M的流量都一样赚钱,为啥还要费功夫呢?

有一位嵌入式工程师就表示:当我跟同事提起要注意这方面的优化时,他们总是给我一个茫然的眼神。

有网友认为:除非各应用商店开始管这事儿,开发商是不会做出改变的。就单说手机厂商就很乐意看到这一场面,内存不够就可以去他们那买新手机了。

他还发现谷歌Play Store好像就不显示应用程序大小。

而一些银行App在这个问题上尤其严重,因为他们知道你不会轻易换银行。

你怎么看?

原博链接:
https://telkins.dev/posts/how-i-shaved-187mb-off-uniteds-airlines-439mb-ios-app/

评论来自:
https://news.ycombinator.com/item?id=30442529&p=2

—  —

「人工智能」、「智能汽车」微信社群邀你加入!

欢迎关注人工智能、智能汽车的小伙伴们加入我们,与AI从业者交流、切磋,不错过最新行业发展&技术进展。

ps.加好友请务必备注您的姓名-公司-职位哦~


点这里👇关注我,记得标星哦~

一键三连「分享」、「点赞」和「在看」

科技前沿进展日日相见~


登录查看更多
0

相关内容

专知会员服务
57+阅读 · 2021年4月7日
【经典书】精通Linux,394页pdf
专知会员服务
92+阅读 · 2021年2月19日
【经典书】C语言傻瓜式入门(第二版),411页pdf
专知会员服务
51+阅读 · 2020年8月16日
【干货书】Python高级数据科学分析,424页pdf
专知会员服务
114+阅读 · 2020年8月7日
【2020新书】从Excel中学习数据挖掘,223页pdf
专知会员服务
90+阅读 · 2020年6月28日
一份简明有趣的Python学习教程,42页pdf
专知会员服务
76+阅读 · 2020年6月22日
《深度学习》圣经花书的数学推导、原理与Python代码实现
TensorFlow Lite指南实战《TensorFlow Lite A primer》,附48页PPT
专知会员服务
69+阅读 · 2020年1月17日
【电子书】C++ Primer Plus 第6版,附PDF
专知会员服务
87+阅读 · 2019年11月25日
电脑装不了 Windows 11?用这个小工具就能搞定
用 Python 开发 Excel 宏脚本的神器
私募工场
26+阅读 · 2019年9月8日
Python NLP 入门教程
开源中国
14+阅读 · 2017年10月1日
国家自然科学基金
0+阅读 · 2015年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
1+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
1+阅读 · 2009年12月31日
国家自然科学基金
0+阅读 · 2009年12月31日
国家自然科学基金
0+阅读 · 2008年12月31日
Arxiv
0+阅读 · 2022年4月19日
VIP会员
相关VIP内容
专知会员服务
57+阅读 · 2021年4月7日
【经典书】精通Linux,394页pdf
专知会员服务
92+阅读 · 2021年2月19日
【经典书】C语言傻瓜式入门(第二版),411页pdf
专知会员服务
51+阅读 · 2020年8月16日
【干货书】Python高级数据科学分析,424页pdf
专知会员服务
114+阅读 · 2020年8月7日
【2020新书】从Excel中学习数据挖掘,223页pdf
专知会员服务
90+阅读 · 2020年6月28日
一份简明有趣的Python学习教程,42页pdf
专知会员服务
76+阅读 · 2020年6月22日
《深度学习》圣经花书的数学推导、原理与Python代码实现
TensorFlow Lite指南实战《TensorFlow Lite A primer》,附48页PPT
专知会员服务
69+阅读 · 2020年1月17日
【电子书】C++ Primer Plus 第6版,附PDF
专知会员服务
87+阅读 · 2019年11月25日
相关基金
国家自然科学基金
0+阅读 · 2015年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2014年12月31日
国家自然科学基金
0+阅读 · 2013年12月31日
国家自然科学基金
0+阅读 · 2012年12月31日
国家自然科学基金
1+阅读 · 2012年12月31日
国家自然科学基金
0+阅读 · 2011年12月31日
国家自然科学基金
1+阅读 · 2009年12月31日
国家自然科学基金
0+阅读 · 2009年12月31日
国家自然科学基金
0+阅读 · 2008年12月31日
Top
微信扫码咨询专知VIP会员