怎样优化app,看Facebook怎样做
周四,Facebook Engineering blog 发表了一篇名为《Improving Facebook on Android》博文。博文从四个方面(Performance,Data
Efficiency,
Networking,Application Size)讲述了Facebook是怎样优化app保证其在不同国家不同类型Android设备上都能表现出良好性能的。
因为原文内容比較
easy理解,这里就直接给出原文。以使上边链接打不开的同学也能看到。《菜鸟成长史:http://blog.csdn.net/zjbpku》
In an effort to connect the next five billion, Facebook began to shift to a mobile-first company about
two years ago. We trained hundreds of employees on mobile development, restructured internal
teams to build for all platforms, and moved to a fast-paced release cycle.
However, our mission extends far beyond building and delivering the best experience on high-end
smartphones and LTE networks. We want Facebook to work for everyone – no matter the region,
network condition, or mobile device.
To help accomplish this goal, a team of product managers and engineers traveled to Africa to
examine mobile performance in developing countries. We purchased several different Android
handsets to test the latest version of the Facebook app – and the testing process proved to be
difficult. The combination of an intermittent, low-bandwidth network connection and a lack of
memory space on the devices resulted in slow load times and constant crashes. We even burned
through our monthly data plans in 40 minutes.We returned to our offices in Seattle, London, and
Menlo Park determined to enhance theFacebook experience on Android – and soon made major improvements
in performance, data efficiency, networking, and application size.
Performance
In terms of performance, we wanted to improve slow start times on old devices. In the beginning,
we focused on instrumenting the startup path and understanding the bottlenecks. There was no
silver bullet in this process – we needed to carefully identify and remove each potential bottleneck.
For example, we found that start times were slower on single-core devices because too many
features concurrently initialized themselves on application startup. We made sure to defer these
initializations until after startup and, in some cases, until the features are used.
We also wanted the stories in News Feed to load faster. In order to rapidly display cached content
on poor networks, we now fetch stories earlier in the process to allow more time to set up
connections and download News Feed. The cold start path has been automated to ensure that we
prevent further regressions in these areas.These changes reduced start times by more than 50 percent
in the six months following the trip to Africa.
Data efficiency
Next, we realized that data is extremely expensive in emerging markets, and purchasing more
data is often a laborious process. Thus, there needed to be a concerted effort to reduce data
consumption within the Facebook app. Interacting with photos is an important part of the
Facebook experience, but it takes a sizable amount of data to download them. If we could
optimize the download size, we could improve data savings and perceived app performance.
First, we investigated the use of alternative compression formats for image transmission. We built
tools to evaluate the impact of several different compression formats on data sizes and eventually
settled on WebP. It offered both great compression performance and efficient support from
Android. The use of WebP for transmitting Facebook images resulted in data savings of 25 to 35
percent compared with JPG, and 80 percent compared with PNG. This all happened without perceived
impact on quality.The next step was to work on loading images at a resolution that devices had the
ability to handle.In the past, we loaded images at maximum resolution to allow for the zoom-in feature.
However,on these kinds of devices this feature was used infrequently. We changed the process of loading
images to only request resolutions equivalent to the size of the viewport in which the images will
appear. Instead of loading a full image, the device only loads the image it needs to show (such as
a thumbnail, preview, or full image at lower resolution). Of course, if someone wants to zoom-in
on an image, we then download a higher resolution image.Finally, we looked over the process used to
cache and reuse images. We tested a number of potential caching strategies, as well as sizes for our
caches, and fine-tuned both to minimize the evictions for images that could be accessed again.
As was the case with performance, it was important to avoid regressing our data efficiency in the
future. We built automated tests and an elaborate system that can attribute data usage to
individual features. This allows Facebook features to understand their data usage in production
and make adjustments if it increases unexpectedly.The work on data efficiency resulted in a 50 percent
reduction in data use compared with earlier last year.
Networking
We also invested heavily in improving the efficiency and reliability of our networking stack. It was
important to implement more modern networking concepts in emerging markets because our
stacks struggled to perform in regions with intermittent networks.
Facebook was an early adopter of OkHttp, a networking stack open-sourced by Square, and it’s
now the stack used by the Android app. OkHttp allows us to support fast retries for intermittent
network situations, take advantage of the SPDY protocol for faster concurrent network
transmissions, and enable powerful instrumentation across the networking stack.
After switching to OkHttp, it became a goal to decrease the number of reports regarding failed
image loads in News Feed. We fine-tuned our image pre-fetching algorithms and altered the
process through which we queue images for download. The process now ensures that the
images expected to be downloaded next are prioritized in the queue and that no images are stuck
in the queue for too long.In combination with better data usage for images, reports of slow or failed
image loads dropped by almost 90 percent over the past year.
Application size
The most popular mobile devices in Africa have little disk space available, which is a significant
barrier to installing app upgrades. This means that people in developing countries often use older
versions of the app that don’t have up-to-date features or take advantage of the improvements
described in this blog post.Our colleagues in the Facebook London office focused on improving app
size efficiency. They approached this problem by utilizing Google Play’s ability to upload multiple
APKs for different Android OSes and screen resolutions. This allows us to exclude excess code for features or
resources not supported on certain mobile devices.As with the other areas, instrumentation and testability
were important to making sure we could bring the app size down. We now have tools that calculate how
each feature contributes to app size and analyze device size regressions.In the end, the app size has
been reduced by 65 percent compared with the beginning of the year.
What comes next?
Our trip to Africa really highlighted the importance of our work on mobile performance, data
efficiency, networking reliability, and application size for emerging markets. We’ve made a
concerted effort to improve in all these areas and achieved a significant amount of success in the
past year.
The lessons learned have already impacted the development of new features. We test all major
features and changes in poor networking scenarios. We have automated verification for various
performance and efficiency characteristics, which allows the features team to receive immediate
feedback on the impact of their code. We also expanded our playbook to other apps, such as
Messenger and Instagram.We will continue to innovate to make the Facebook experience better in emerging
markets, and share tools and information that can help developers build apps that work well on different
handsets, network environments, and operating systems.
注:以上英文内容来自:Facebook Code https://code.facebook.com/posts/485459238254631/improving-facebook-on-android/
怎样优化app,看Facebook怎样做的更多相关文章
- 优化 App 的启动时间
这是一篇 WWDC 2016 Session 406 的学习笔记,从原理到实践讲述了如何优化 App 的启动时间. App 运行理论 main() 执行前发生的事 Mach-O 格式 虚拟内存基础 M ...
- WWDC2018 之 优化 App Assets Optimizing App Assets
该篇博客记录了观看WWDC Session227<Optimizing App Assets>的内容以及一些理解. 引言 该session主要讲述了使用Assets Catalog的新特性 ...
- 5个可以帮你优化App的优秀网站
也许现在有一款App可以提供所有你需要的,你不需要的,或者你可以想象到的内容.但是,有多少App真的可以不仅满足需求而且还能提供很好的用户体验呢? 相信很多APP并没有这样的能力.有一些APP的设计特 ...
- Android性能优化-App后台优化
原文链接 Background Optimizations 前言 后台进程是内存和电池敏感的.一个隐式的broadcast可能会启动很多监听它的后台进程,即使这些进程可能做得工作不多.这可能丢设备性能 ...
- Android性能优化-App启动优化
原文地址:https://developer.android.com/topic/performance/launch-time.html#common 通常用户期望app响应和加载速度越快越好.一个 ...
- IOS-5个可以帮你优化App的优秀网站
也许现在有一款App可以提供所有你需要的,你不需要的,或者你可以想象到的内容.但是,有多少App真的可以不仅满足需求而且还能提供很好的用户体验呢? 相信很多APP并没有这样的能力.有一些APP的设计特 ...
- 涉嫌垄断的App Store,到底做了什么让开发者暴怒
Store,到底做了什么让开发者暴怒" title="涉嫌垄断的App Store,到底做了什么让开发者暴怒"> 什么行业最赚钱?不是你想象中的餐饮.互联网. ...
- 小师妹学JVM之:深入理解JIT和编译优化-你看不懂系列
目录 简介 JIT编译器 Tiered Compilation分层编译 OSR(On-Stack Replacement) Deoptimization 常见的编译优化举例 Inlining内联 Br ...
- [转]Code! MVC 5 App with Facebook, Twitter, LinkedIn and Google OAuth2 Sign-on (C#)
本文转自:https://www.asp.net/mvc/overview/security/create-an-aspnet-mvc-5-app-with-facebook-and-google-o ...
随机推荐
- 十一. Python基础(11)—补充: 作用域 & 装饰器
十一. Python基础(11)-补充: 作用域 & 装饰器 1 ● Python的作用域补遗 在C/C++等语言中, if语句等控制结构(control structure)会产生新的作用域 ...
- (C/C++学习笔记) 三. 作用域和可见性
三. 作用域和可见性 ● 标识符的作用域 标识符的作用域是标识符在程序源代码中的有效范围,从小到大分为函数原型作用域.块作用域(局部作用域),文件作用域(全局作用域). 1. 函数原型作用域 函数原型 ...
- ui-router ng-router
开发中常用ui-router来设置路由: ui-router使用很简单,延续了之前ngRoute的特点. 1.首先得注入ui.router模块. 接下来就是简单的配置 2.$stateProvider ...
- Xilinx FFT IP v9.0 使用(一)
reference:https://blog.csdn.net/shichaog/article/details/51189711 https://blog.csdn.net/qq_36375505/ ...
- SharePoint REST API - 确定REST端点URL
博客地址:http://blog.csdn.net/FoxDave SharePoint REST端点URI的结构 在你能够通过REST访问SharePoint资源之前,首先你要做的就是找出对应的 ...
- JavaWeb:c3p0配置问题java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector
错误显示 java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector at dbdemo.JdbcUtils.<clinit> ...
- 百杂讲堂之为什么32位系统只能操作4g内存
百杂讲堂之为什么32位系统只能操作4g内存 计算机内存中很多的单元,每一个单元就是一个字节,一个字节有8位.每一个单元有两种状态:0和1. 所以 两个单元就有4个组合: 3个单元就有8个组合: 依次类 ...
- 读取文件时,使用file.eof()判断结尾注意事项
今天写一个小功能需要读取文件,在判断文件结尾时使用了以下语句: while(infile.eof() && infile.good()) { infile.read((); encod ...
- python检测网络延迟
#!/usr/bin/env python # coding: utf-8 # coding: cp950 ''' Create Date: 2012-11-06 Version: 1.0 Descr ...
- ubuntu + samba 共享失败
主机版本:ubuntu14.04 问题描述:Samba服务配置后仍然不通. samba服务这么成熟的东西,本以为在ubuntu上修改下smb.conf重启就得了,但是访问还是失败. 表现是,可以看到s ...