- 能知道媒体文件压缩的原理
整个优化经历了两个阶段
-
第一阶段是上传模块重构,并且通过UI和数据的分离,提升了扩展性,逐步被运用到产品的各个模块中
-
第二阶段是上传尺寸的优化,通过对视频文件的压缩,大幅减少用户的上传等待时间。
chapter 1.上传框架重构
================
评估现有模块表现
-
使用中低配置手机运行apk,查看上传模块实际表现
-
使用Charles抓包工具,观察每个上传文件体积是否被压缩到合理范围、对上传模块发送的http请求按照功能对其分类,检查是否可以合并同类请求
-
退出上传,查看上传后续步骤是否被停止;大文件重新上传是否跳过已上传的数据块
-
查看上传后的结果是否正常播放、是否失真、音频异常
上传模块现存问题
-
UI和上传代码耦合在一起,难以拓展维护
-
停止上传后仍然继续上传,说明流程控制有问题
-
在上传时,对每个文件会进行尺寸压缩、计算md5值,比较费时
-
每个文件上传前都会发送一次存在校验(根据文件md5值),导致在上传的场景中会发送多次http请求校验文件存在
-
视频文件没有做压缩,导致上传费时
整体设计思路
上传设计思路.png
-
数据UI分离:使用观察模式,抽离UI部分代码。使用弱引用设置观察者,避免生命周期不一致引起的内存泄漏。
-
费时操作前置:在选择图片的步骤,开启异步线程压缩图片、计算md5,将费时操作提前处理掉_(此步骤在mx4 pro上处理拍照的图片耗时100