
文章图片

文章图片

文章图片

文章图片

文章图片
前些日子 , 一个手机QQ安装包就要快900MB的事儿在网上吵得沸沸扬扬 。
虽然最后大家发现它主要为了视频通话特效多了一个虚幻引擎 , 但网友还是感叹:
现在的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在这个问题上尤其严重 , 因为他们知道你不会轻易换银行 。
【程序员|程序员用5分钟,把一个400多MB的苹果安装包削掉了187MB】你怎么看?
- harmonyos|中国移动大招来袭!29元/月+103G通用流量+200分钟通话,民心福利!
- 小米科技|用过小米12S后才知道中杯也是很香的
- 空调|看看空调常见小故障,哪些是用户自己可以快速修复的
- 努比亚|美下达最后通牒,逼韩国围堵中国芯片,中方将采用新技术反击美国
- ColorOS|ColorOS 13内测版本开启!控制中心和桌面将有大改,使用更方便
- 软件|cpu的使用寿命大概有多少年?
- 科技日报 |职业教育信息化下一站: 数字技术由辅助手段走向深度应用
- 高通骁龙|轻松用四年,1500元左右的高性能机型盘点,只推出这四款
- 软件|新买的手机不要着急插卡使用,先设置一下这三个地方,丝滑如初!
- 软件|3款小众又实用的软件,“不能让它火啊”,道出网友心中的喜爱
