周末闲来无事,翻遍各大视频网站实在是找不到什么好看节目。既然从娱乐的角度来说视频不好看,那我们就来从技术的角度来看下各家视频APP吧。技术的角度,话题还是太大,实在是没有能力做一个全面的比较。记得曾经有位小伙伴曾说过,一切性能问题追究到底都会成为内存问题。那我们就从内存的角度来简单分析下优酷、爱奇艺和腾讯视频三家视频APP。
一、基础知识 - dumpsys命令
对于Debug版本APP我们可以使用Android Studio
自带的Profiler
来查看应用对内存的使用情况。想要查看Release版本应用的内存使用情况就得靠dumpsys
这个工具了。dumpsys
运行在Android设备上,我们可以通过adb命令来运行它。通过dumpsys
我们可以获取到所有正在运行的系统服务的特征信息。系统服务非常多,我们可以通过如下命令查看能够使用dumpsys
来查看服务特征信息的服务列表。
adb shell dumpsys -l
上图是我在华为P9上测试
dumpsys -l
的截图,服务列表很长,只截取了一部分,截图中看着眼熟的服务就activity
这个服务了,这个通常用来查看四大组件的信息,如常见的adb shell dumpsys activity activities
。常用还有如下服务。
服务名 | 作用 |
---|---|
input | 获取系统输入设备的信息,如键盘、触摸屏等 |
batterystats | 获取电量使用信息 |
gfxinfo | 获取UI渲染信息 |
meminfo | 获取内存使用信息 |
cpuinfo | 获取CPU使用信息 |
netstats | 获取网络使用信息 |
1.1 dumpsys命令语法
dumpsys
命令的语法也非常简单,直接adb shell dumpsys
即可。但这样获取的是所有服务的信息,信息非常多,想要过滤到我们所关注的信息,还需要在命令后跟上我们所关注的服务名。如今天我们主要关注内存,对应的服务名是meminfo
,那么命令就是adb shell dumpsys meminfo
。这个命令获取的是设备上所有进程的内存使用情况,我们今天关注的是优爱腾三个APP的内存,所以我们还得再命令后加上进程名来过滤adb shell dumpsys meminfo com.youku.phone
1.2 dumpsys输出信息解析
如上所示内存信息,一般关注Pss Total
和 Private Dirty
这两列。这是两种不同的内存统计方式。
Private (Clean and Dirty) RAM
私有内存,这种方式只统计了当前进程独享的内存,Private Clean
和Private Dirty
的总和就是当前进程的独占内存,当进程销毁时系统会回收这部分内存。Dirty RAM
是必须保存在内存中数据,如程序运行过程中的变量数据,这部分内存中的东西未成为垃圾数据之前必须一直保存在内存中;Clean RAM
是从持久化文件中加载的数据,如程序执行时加载的代码,这部分内存中的数据可以丢掉,再次使用时可以再从持久化文件中再次加载。
Proportional Set Size (PSS)
比例集大小,这中方式统计的内存除了进程独享内存外,还包括通过共享页面与其他进程共享的内存。共享内存的一个常见用途是在进程之间共享“代码”内存页(加载只读可执行代码的内存区域)。比如外部库和JVM的可执行代码是存放在可以跨进程安全共享的内存区域。共享内存会根据共享进程数量分摊到各个进程中。
另外值得一提的是Objects
区域列出来的是当前进程存活的对象数量,这些信息对分析内存泄露问题也有指导意义。例如ViewRootImpl
代表了当前进程存活的根view个数,ViewRootImpl
是和window
一一对应的,从ViewRootImpl
的数量我们也可以分析是否有dialog或者其他窗口导致的内存泄露。
二、优爱腾内存对比
APP | 包名 | 版本 |
---|---|---|
优酷 | com.youku.phone | 7.6.7 |
爱奇艺 | com.qiyi.video | 10.2.0 |
腾讯视频 | com.tencent.qqlive | 6.8.0 |
上面是测试使用的APP版本。为了对比应用自己申请的内存大小,我们列出来Private Dirty
、Private Clean
及其他们的和Private Total
。验证了以下三个场景:
- 打开APP进入首页不做任何操作稳定30s后测量内存数据;
- 在首页往下滑动10屏以上稳定后测量内存数据;
-
退出应用杀掉进程,重新进入首页,搜索《人民的名义》点击01集进入播放页,关闭弹幕全屏播放高清资源一分钟后测量内存数据;
测量数据如下,单位都是KB。
上面是三家APP不同场景内存对比图,实现同样的功能内存耗用越低越好。可以看出,优酷在首页上内存的使用是最为高效,爱奇艺的播放器在内存使用方面做得最好。还有一点就是爱奇艺在每个阶段Private Clean
使用都是最小的。