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

安卓应用卡顿或性能低下的主要原因是垃圾回收器(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. 过多的线性处理:

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

相关推荐
张拭心25 分钟前
春节后,有些公司明确要求 AI 经验了
android·前端·人工智能
张拭心36 分钟前
Android 17 来了!新特性介绍与适配建议
android·前端
Kapaseker3 小时前
Compose 进阶—巧用 GraphicsLayer
android·kotlin
黄林晴3 小时前
Android17 为什么重写 MessageQueue
android
阿巴斯甜1 天前
Android 报错:Zip file '/Users/lyy/develop/repoAndroidLapp/l-app-android-ble/app/bu
android
Kapaseker1 天前
实战 Compose 中的 IntrinsicSize
android·kotlin
xq95271 天前
Andorid Google 登录接入文档
android
黄林晴1 天前
告别 Modifier 地狱,Compose 样式系统要变天了
android·android jetpack
冬奇Lab2 天前
Android触摸事件分发、手势识别与输入优化实战
android·源码阅读
城东米粉儿2 天前
Android MediaPlayer 笔记
android