终端开发

Android开发之FileProvider相关知识 Android 权限 及设置描述信息 局域网开启 Android ADB 无线调试 安卓开发那些事之开发规范 安卓组件化之组件通信及拦截 安卓开发那些事之版本管理 安卓组件化之持续集成与自动构建 安卓组件化之组件调试和运行 安卓组件化之组件管理(导入、依赖、升级) 安卓组件化之框架设计 安卓开发那些事总纲 Android Textview 对HTML 的支持 appium 爬坑之基于 Chromedriver 测试 Android webview Linux 搭建 Android 编译构建环境 appium爬坑之iMac上基于appium多设备并发测试 appium爬坑之iMac上appium环境搭建及使用真机测试Android项目简介 H5页面通过指定Schema拉起Android应用 Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 iMac上 Xcode 相关设置及常见问题 iOS开发 -- 首次使用Xcode运行iOS项目代码 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 Android安装包精简系列之资源精简 Android安装包精简系列之图片优化 Android安装包精简系列之为什么要优化精简安装包 Android安装包精简系列(总纲) Android安装包精简系列之图标转字体 Gradle 相关资料汇总 Android编译常见错误解决 Android编译编译速度提升 终端基于gradle的开源项目运行环境配置指引 制作终端产品演示的gif 一个关于APK Signature Scheme v2签名的神奇bug定位经历 如何随apk一起打包并使用SQLite SDK热更之gradle插件(如何在SDK代码中自动插桩及如何生成补丁包) 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 SDK热更系列之概述(持续整理编辑中~) SDK热更系列之SDKHotfix待优化点 Android 终端开发相关的一些神图(持续更新) SDK热更系列之Demo项目介绍概述 SDK热更系列之Demo体验方法 SDK热更系列之如何获取应用在当前设备上的so对应的指令集 Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 ADB命令系列之再说ADB 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 ADB命令系列之 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书)及命令行获取 keystore 公钥等信息 Robotium二三事-Android自动化测试系列(二) Robotium介绍-Android自动化测试系列(一) Android开发中遇到的那些坑 Eclipse使用中部分经验总结 Android中关于Nativa编译(NDK、JNI)的一些问题 Android简单实现的多线程下载模块 Android内存耗用之VSS/RSS/PSS/USS ADB命令系列之 Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 ADB命令系列之 Base Command Android Log的那些坑…………

开发工具

Linux JDK 安装、卸载、路径查看 替换Jcenter,发布开源代码到 Sonatype Maven Central 使用 gitstats 分析代码仓库 使用 Jekyll 搭建技术博客并部署到 CentOS 服务器 开发中常用的文档管理、云端笔记等效率工具介绍 iMac(OS X)常用图片处理工具介绍 使用 Octopress 搭建技术博客并使用腾讯云静态网站托管 使用腾讯云静态网站托管个人博客 使用 Jekyll 搭建技术博客 iMac上安装Python2.7 和 Python3 iMac 使用自带的 Apache 启用本地web服务 发布开源代码到jcenter Gradle环境变量那些事 iMac搭建jekyll本地环境 iMac(OS X)开发和使用中经验汇总(持续更新) iMac配置基于crontab的定时任务 iMac配置支持读取NTFS硬盘 新iMac机器装机及开发环境搭建攻略 git常用命令整理(已包括branch、tag等持续更新~) iMac使用过程中的简单故障解决 iMac上RubyGems相关的问题汇总 开发中常用的一些Chrome插件介绍 iMac(OS X)日常开发中各种代理设置方法汇总(shell、Android Studio、gem、npm) Markdown格式优化及使用技巧 iMac下制作含透明度图片及判断图片透明度 iMac(OS X)中设置大小写敏感的分区并切换 Linux & MacOS中一些常用命令备忘 iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 iMac(OS X)El Capitan 更新遇到的那些坑 vi常用命令 iMac(OS X)常用开发工具介绍 iMac(OS X)不可或缺的套件管理器 —— Homebrew 开发环境通用设置 windows中一些常用命令备忘 问题定位之快速模拟请求 Ant中的SVN 使用 Markdown语法简介 SVN 常用命令

标签

android 50

ADB快捷输入法 - AAF 开发中图片图标处理常用工具资源 Linux 搭建 Android 编译构建环境 H5页面通过指定Schema拉起Android应用 Android编译常见错误解决 一个关于APK Signature Scheme v2签名的神奇bug定位经历 关于Android的APK Signature Scheme v2签名相关的资料汇总 封装HttpURLConnection实现的简单的网络请求库 一款基于Java环境的读取应用包名、签名、是否V2签名等基本信息的工具 Android的APK Signature Scheme v2签名及一款基于Java环境的校验工具介绍 如何使用Eclipse开发可执行Jar程序,并生成混淆过的jar程序 Android 相关的学习资料整理(持续更新) macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio Android开发常用命令备忘 Google也看不下去被玩坏的悬浮窗了么? Android开发常用工具资源 Android 终端开发相关的一些神图(持续更新) Gradle Android插件使用的中那些特别注意的点 Experimental Plugin User Guide(From Android Tools Project Site) iMac(OS X)搭建私有maven仓库,提供Nexus Responsitory镜像 基于Android Studio使用gradle构建包含jni以及so的构建实例 基于Instrumentation框架的自动化测试 - Android自动化测试系列(四) Instrumentation框架介绍-Android自动化测试系列(三) 关于终端设备的设备唯一性的那些事之MAC地址 关于终端设备的设备唯一性的那些事之IMEI Android 检查应用是否有root权限 iMac(OS X)El Capitan 更新遇到的那些坑 ant常见错误解决方案 Gradle介绍 iMac上Android Studio 相关设置及常见问题 ADB命令系列之再说ADB 再看Android官方文档之分享 再看Android官方文档之Fragment&数据保存 再看Android官方文档之Activity&Intent 再看Android官方文档之ActionBar和兼容性 ADB命令系列之 adb shell input(Android模拟输入)简单总结 再看Android官方文档之建立第一个APP Android开发调试常用工具 ANR(网络资料整理) Java参数引用传递引发的惨案(又一次Java的String的“非对象”特性的踩坑经历) android.view.WindowManager$BadTokenException,Unable to add window Android签名校验机制(数字证书)及命令行获取 keystore 公钥等信息 Eclipse使用中部分经验总结 Android内存耗用之VSS/RSS/PSS/USS ADB命令系列之 Advanced Command URL编码中的空格(编码以后变为+) Android MD5后 bye数组转化为Hex字符串的坑(记一次为女神排忧解难的经历) Android学习之路 ADB命令系列之 Base Command Android Log的那些坑…………

tags 53

替换Jcenter,发布开源代码到 Sonatype Maven Central Android开发之FileProvider相关知识 子勰开源项目展示 照片整理系之视频归档整理方案 使用 gitstats 分析代码仓库 Android 权限 及设置描述信息 局域网开启 Android ADB 无线调试 安卓开发那些事之开发规范 安卓组件化之组件通信及拦截 安卓开发那些事之版本管理 安卓组件化之持续集成与自动构建 安卓组件化之组件调试和运行 安卓组件化之组件管理(导入、依赖、升级) 安卓组件化之框架设计 安卓开发那些事总纲 Android Textview 对HTML 的支持 使用 Jekyll 搭建技术博客并部署到 CentOS 服务器 2018年春节仙本那海岛游行程规划 照片整理系列之单次整理流程 照片整理系列之整理及归档的总体方案 使用 Octopress 搭建技术博客并使用腾讯云静态网站托管 使用腾讯云静态网站托管个人博客 使用 Jekyll 搭建技术博客 颜色透明度对照表 Android JSBridge简介 Gradle插件开发系列之发布gradle插件到开源库 Gradle插件开发系列之开发第一个gradle插件 Gradle插件开发系列之gradle插件调试方法 发布开源代码到jcenter Gradle环境变量那些事 Gradle插件开发系列之总纲 一款检查Gradle依赖配置是否冲突的插件 记一次升级Android Gradle Plugin后databing编译报错填坑经历 服务器 迁移到 腾讯云 记录 2018年春节沙巴仙本那海岛游 聚会桌游助手 nodejs入门之后台服务的几种启动方式 nginx下多域名配置示例 nodejs入门之连接mysql mysql迁移之新建用户、备份还原数据库 iMac配置基于crontab的定时任务 iOS开发 -- 首次使用Xcode运行iOS项目代码 新iMac机器装机及开发环境搭建攻略 旅行中不可或缺的软件 iMac上RubyGems相关的问题汇总 接口设计六大原则 Canvas上更高效的画SVG 微信小程序开发之SVG的使用 旅行出行前准备列表 使用Android Studio开发可独立运行(runnable)混淆过的Jar程序 2017年端午川西滇北香格里拉环线(近200张图慎点) 照片整理系列之基于命令行的照片整理及查看工具 Gradle 相关资料汇总

Android安装包精简系列之为什么要优化精简安装包

「 终端开发 」 ——  2017年04月01日

写在前面

这篇文章是应用安装包优化相关的第二篇,这里主要总结一下为什么要优化精简安装包,包括为什么安卓包越来越大和精简优化安装包有哪些好处和弊端。

为什么apk越来越大

不管是平时的使用过程中,还是业务的数据监测,都可以感觉到目前单款应用的安装包已经越来越大,是什么原因导致这些问题呢?感觉主要是几个方面:

设备硬件性能提升

终端手机的硬件性能提升是非常明显的,甚至更新的速度比摩尔定律预测的还要快,这里与安装包主要包括:

  • 更大更好的屏幕、更快的绘制速度

    由于屏幕越来越大,而且分辨率越来越高,加上处理速度的提升,为了更用户更好的体验,在终端开发中越来越多的人使用高分辨率,效果更好的图片和其他资源。

  • 设备类型增加

    由于硬件的蓬勃发展和不断更新,为了更快的计算速度,CPU的更新速度也越来越快,目前主流的CPU类型包括arm和x86相关的多个系列,为了更好地兼容设备指令集,带来更好的运算效果,很多开发者需要apk同时兼容多种指令集类型,这也导致了安装包的增加。

Android开发技术越来越成熟

  • 第三方扩展库越来越多

    随着开源社区的成熟和Android相关的技术方案的沉淀,目前对于网络请求、数据库、文件操作、图片加载、UI控件(各种view,进度条、dialog等等)等这种只要比较通用的技术基本上都已经有各种成熟的框架和扩展库,很多开发者在开发中不考虑性价比,为了实现一些很小的功能为了开发的便捷就引入各种框架,因此导致项目代码中存在大量第三方库相关的内容,导致安装包不断增加。

  • 开发框架越来越多

    同样因为相关技术的成熟,目前对于Android开发的整体框架也越来越多,例如MVP、MVVM等等,再加上国内特殊环境下热修复、动态加载等技术的大行其道,很多开发者同样不考虑性价比,无论什么类型的应用,都是各种能力均完全具备,做大做全或者使用很复杂的框架导致安装包不断增加。

Android碎片化越来越严重

Android的开放带来了Android的繁荣,但是也带来了非常严重的碎片化的问题,主要表现在

  • 厂商太多、os版本太多、更新太慢

    截止目前,Android 8已经发布了开发者预览版,但是目前市面上主要的Android版本还集中在Android 4.X ,使用Android N的比例更低。同时加上各大厂商的制定ROM,Android设备的碎片化问题格外严重,国内厂商为了厂商的利益做了很多并不友好的修改,导致很多开发者不得不对不同的厂商ROM以及Android的不同版本在代码程度上添加兼容,这部分兼容的逻辑也很重

  • 分辨率太多

    除了操作系统的版本太多以为,Android碎片化更严重的就是分辨率了,Android的屏幕分辨率多到无法数清。为了解决不同屏幕下分辨率的问题,Android提供了对应的解决方案,但是带来的问题就是相同的资源,需要根据不同的分辨率准备很多套,也导致资源占用很多。

产品功能的盲目添加

这个其实最容易理解,随着移动互联网的发展,目前成熟的超级app越来越多,很多开发者都希望自己的app能成为下一个超级app。在不知道怎么成为下一个超级app的时候,最简单的做法就是做一个百科的大而且全的app,最好能包罗万象。最后导致安装包不断变大,但是很多用户仅仅使用很少一部分功能。

精简应用的安装包会有什么好处

上面提了那么多导致安装包变大的原因,貌似基本上绝大部分都是为了提供更好的应用体验,那为什么还要精简安装包呢?

提高下载转化率

安装包越小,用户下载所需要的时间越短,用户的下载安装转化率也就越高。一个100M的应用,用户即使点了下载一看这么大的包也会犹豫要不要下载,如果下载速度很慢也很容易放弃。一个10M的应用,用户点了如果用户还在犹豫要不要下的时候已经下载完了,安装体验的可能性就更高。

降低服务器带宽

一般如果应用的用户量不是特别大的时候不会很明显,当用户量达到一定级别,如果又没有灰度策略和通过应用市场发布的策略的话,每次版本更新就会出一个很高的下载高峰,这个时候带宽可能会很高,目前带宽都是按照峰值收费,这就会导致以为峰值毛刺承担比较高的成本。

尽量降低用户的流量消耗

应用的安装和更新都需要经过网络将其下载,app越大,流量越多。虽然目前流量资费已经大大的降低,但是能节省还是帮用户节省一些比较好。

其他

精简应用的安装包又会有什么弊端

精简应用的安装包的弊端取决于你使用了哪些精简安装包的策略,这些要具体问题具体分析,这部分内容我会在具体介绍具体的优化方案的时候介绍。

精简安装包时一些总体思想

在后面系列的文章中我会具体介绍各种安装包精简相关的方案,里面有些是我们使用的,有些我们并没有使用,但是一并汇总整理了。这里再增加几个我们在安装包精简的时候的总的考虑,避免后面多次解释。

  • 用户所使用的移动网络有了比较大的变化

    经过几年的发展,目前移动网络已经有了比较大的变化,不论是传输速度还是网络质量都有了很大的提升,而用户的流量也越来越多,对于流量的关心程度已经大大降低。因此我们在进行安装包精简的时候会有部分内容是在使用的时候直接去下载,而不是放在安装包里面。

  • 应用中的绝大多数功能都是长尾功能

    前面已经提到了,所有的应用都想成为超级APP,保罗万象。然而绝大部分功能其实用户很少用到,因此对于这部分长尾的功能相关的内容,我们可能会考虑通过多种形式下发,而不是打包在安装包。

  • 用户体验至上但是不能是唯一标准

    对于有些场景,如果选择了云端下发、动态拉取等逻辑的话,必然会对用户体验产生影响,例如会增加等待等,但是如果这种影响不会导致服务不可用等问题,那这种通过提供有损的用户体验来达到比较好的效果的方案还是可行的。我们最终的目标是用户体验和技术方案之间达到平衡。


赞赏

取消
微信扫一扫,赞赏子勰
扫码支持
屌丝程序猿,鸡血攻城狮!努力学技术,潜心做精品!