安卓应用卡顿、性能低下的背后原因

安卓应用卡顿或性能低下的主要原因是垃圾回收器(GC)运行过于频繁。

当GC运行时,应用本身实际上并未运行。

通常情况下,为了实现流畅的UI渲染,安卓应用需要每16毫秒更新一次UI(考虑到60FPS的刷新率,即1000毫秒/60 ≈ 16毫秒)。

因此,如果GC运行时间过长,应用无法及时更新UI,导致本来高刷的屏幕出现了跳帧,从而表现出卡顿。

Google目前给出了一些解决办法:https://support.google.com/android/answer/7667018

导致安卓应用卡顿的一些最重要原因:

  1. 主线程任务过重
  2. 糟糕的UI/UX设计
  3. 瓶颈效应
  4. 过多的线性处理

1. 主线程任务过重:

多线程并非万能药。如果应用线程模型存在阻塞、等待等问题,即使拥有多CPU/多核心也无法发挥优势。当负载增加时,不充分的并发处理能力会影响应用性能,此时单纯增加CPU数量也无济于事。

2. 糟糕的UI/UX设计:

如果用户界面本身设计不好,那不管是什么系统来了也没用。

3. 瓶颈效应:

一个应用的运行速度只能和系统中最慢的环节一样快。这是因为网络、数据库(DB)和应用服务器都需要足够快才能确保最佳性能。最常见的瓶颈点包括代理服务器、Web服务器、数据库、路由器和中间件。通过减少对中心辐射型(hub/spoke)结构的依赖,使用冗余的复制基础架构,并消除单点故障来减少瓶颈。

4. 过多的线性处理:

有时,应用需要进行大量处理,这涉及对海量数据进行大量计算,非常耗时。

相关推荐
移动开发者1号8 分钟前
ReLinker优化So库加载指南
android·kotlin
山野万里__15 分钟前
C++与Java内存共享技术:跨平台与跨语言实现指南
android·java·c++·笔记
Huckings17 分钟前
Android 性能问题
android
移动开发者1号43 分钟前
剖析 Systrace:定位 UI 线程阻塞的终极指南
android·kotlin
移动开发者1号43 分钟前
深入解析内存抖动:定位与修复实战(Kotlin版)
android·kotlin
whysqwhw1 小时前
OkHttp深度架构缺陷分析与革命性演进方案
android
Digitally3 小时前
如何将文件从 iPhone 传输到 Android(新指南)
android·ios·iphone
whysqwhw4 小时前
OkHttp深度架构缺陷分析与演进规划
android
用户7093722538514 小时前
Android14 SystemUI NotificationShadeWindowView 加载显示过程
android
木叶丸4 小时前
跨平台方案该如何选择?
android·前端·ios