成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

移動(dòng)開發(fā) Android
下面我們就以兩個(gè)實(shí)例,從技術(shù)的角度來(lái)看一下事件發(fā)生時(shí)候的情況和原因,希望看到這篇文章的開發(fā)者,檢查一下自己的應(yīng)用是否有這個(gè)問(wèn)題,有則改之,無(wú)則恭喜

當(dāng)一個(gè) Android App 退到后臺(tái)之后,只要他沒(méi)有被殺死,那么他做什么事情大家都不要奇怪,因?yàn)檫@就是 Android。但是當(dāng)用戶知道一個(gè)你一個(gè) App 退到后臺(tái)之后還在持續(xù)做無(wú)效的動(dòng)畫,而這個(gè)動(dòng)畫完全是無(wú)意義的,而且用戶還不知道他在做動(dòng)畫,消耗用戶那可憐的電量的時(shí)候,輕則被多任務(wù)殺掉,禁止后臺(tái)運(yùn)行,重則直接卸載。

一般的開發(fā)者很難發(fā)現(xiàn)這個(gè)問(wèn)題,但是如果你經(jīng)常使用 Systrace ,多開幾十個(gè)應(yīng)用然后退回到桌面,左右滑動(dòng)抓取 Systrace ,就可以很容易發(fā)現(xiàn),總有那么幾個(gè)后臺(tái)的應(yīng)用,還在頻繁地做無(wú)效的動(dòng)畫。

這里說(shuō)的后臺(tái)做動(dòng)畫,指的是由于某種原因,應(yīng)用在退到后臺(tái)之后,用戶看不到任何這個(gè) App 界面的時(shí)候,他仍然在后臺(tái)不斷地更新,耗費(fèi) CPU。引起這個(gè)問(wèn)題的原因可能有好多個(gè),畢竟 往 Choreographer 扔 CALLBACK_ANIMATION 的地方太多了,而且每個(gè)應(yīng)用可能都不一樣,但最終還是需要各個(gè)應(yīng)用去做修復(fù)

下面我們就以兩個(gè)實(shí)例,從技術(shù)的角度來(lái)看一下事件發(fā)生時(shí)候的情況和原因,希望看到這篇文章的開發(fā)者,檢查一下自己的應(yīng)用是否有這個(gè)問(wèn)題,有則改之,無(wú)則恭喜

實(shí)例 - 網(wǎng)易新聞

我們?cè)谑褂镁W(wǎng)易新聞后,將網(wǎng)易新聞退到后臺(tái),然后左右滑動(dòng)桌面,抓 Systrace 來(lái)看:

網(wǎng)易新聞到后臺(tái)之后還在持續(xù)做 Animation 的回調(diào)(紅框內(nèi)),每一幀都還是在 doFrame 操作

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

放大每一個(gè) doFrame 來(lái)看,Choreographer 中的 input 和 traversal 都沒(méi)有觸發(fā),只有 animation 的回調(diào)一直在執(zhí)行

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

我們把這份 Trace 上的 cpu 部分全選,然后下面按照 Wall Duration 排序,可以發(fā)現(xiàn)網(wǎng)易新聞后臺(tái)動(dòng)畫執(zhí)行時(shí)間最長(zhǎng)。應(yīng)用已經(jīng)在后臺(tái)且不可見的時(shí)候,還在這么頻繁地工作,占用 CPU 資源,消耗電量,實(shí)在是不應(yīng)該

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

抓對(duì)應(yīng)的 MethodTrace 來(lái)看,就是在做動(dòng)畫,沒(méi)有進(jìn)行關(guān)閉 ,動(dòng)畫依舊在每一幀進(jìn)行 onAnimationUpdate 的回調(diào) ,可以看到這里是因?yàn)槭褂昧?Airbnb 的 Lottie 庫(kù)導(dǎo)致的,動(dòng)畫沒(méi)有關(guān)閉,所以還是一直在做觸發(fā)

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

實(shí)例 - QQ音樂(lè)

啟動(dòng) QQ 音樂(lè),然后回到桌面, 左右滑動(dòng)桌面并抓取 Systrace 和 MethodTrace ,可以看到跟上面的網(wǎng)易新聞的表現(xiàn)一致

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

抓取了 QQ 音樂(lè)的后臺(tái)動(dòng)畫時(shí)候的 MethodTrace 發(fā)現(xiàn),也是由于退到后臺(tái)之后,沒(méi)有暫停動(dòng)畫導(dǎo)致的,也是 Airbnb 的 Lottie 的鍋, 而且 QQ 音樂(lè)有三個(gè)動(dòng)畫沒(méi)有停止,比網(wǎng)易新聞還要嚴(yán)重一些

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

放大后可以看到

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

當(dāng)然也不是每一個(gè)都是 Airbnb 的 Lottie 動(dòng)畫庫(kù)引起的,比如下面這個(gè),就是普通的動(dòng)畫沒(méi)有結(jié)束

Android 中的“后臺(tái)無(wú)效動(dòng)畫“行為分析

根本原因

根本原因是應(yīng)用在不可見之后,沒(méi)有將動(dòng)畫暫停,導(dǎo)致應(yīng)用切換到后臺(tái)之后,依然在刷新動(dòng)畫的回調(diào),但此時(shí)由于是不可見的,不會(huì)觸發(fā) Input Callback 和 draw Callback ,所以也不會(huì)有任何的繪制操作,也就是說(shuō)這個(gè) Animation 的刷新完全是沒(méi)有意義的(當(dāng)然也有可能是業(yè)務(wù)需求?)

上面兩個(gè)例子里面,網(wǎng)易新聞和 QQ 音樂(lè)都是因?yàn)槭褂昧?Lottie 來(lái)實(shí)現(xiàn)動(dòng)畫,但是沒(méi)有正確的關(guān)閉導(dǎo)致的。

開發(fā)建議

Lottie 庫(kù)的 issue 列表里面有人提到了這個(gè)情況:

提出問(wèn)題:

  • I recently did some benchmarking on an app which uses lottie to do some animations (autoplay and looping). I noticed that there is quite some CPU usage when the app is in the background and tried to investigate.
  • It seems to me looping animations do not pause/stop when the containing LottieAnimationView is off screen, and/or the Activity is paused.
  • I believe this is due to the cleanup code being only in onDetachedFromWindow() which is not necessarily being called once the Activity goes into a paused state and most definitely not, when the view is simply not visible (GONE, INVISIBLE ) anymore.

解決方法:

  • Overriding LottieAnimationView and doing the following solves the visibility issue for me and Lottie is paused when not visible.

 

  1. @Override 
  2. protected void onVisibilityChanged(@NonNull View changedView, int visibility) { 
  3.     super.onVisibilityChanged(changedView, visibility); 
  4.     if (visibility == VISIBLE && wasAnimatingWhenVisibilityChanged) { 
  5.         resumeAnimation(); 
  6.     } else { 
  7.         if (isAnimating()) { 
  8.             wasAnimatingWhenVisibilityChanged = true
  9.             pauseAnimation(); 
  10.         } else { 
  11.             wasAnimatingWhenVisibilityChanged = false
  12.         } 
  13.     } 

總之就是 : 當(dāng) App 不可見的時(shí)候,停止所有的動(dòng)畫:pauseAnimation!!!

責(zé)任編輯:未麗燕 來(lái)源: Android Performance
相關(guān)推薦

2022-09-28 11:34:27

用戶行為數(shù)據(jù)業(yè)務(wù)

2017-07-24 09:18:55

大數(shù)據(jù)數(shù)據(jù)分析行為事件分析

2023-06-28 07:54:44

數(shù)據(jù)治理數(shù)據(jù)分析

2015-12-31 17:47:54

2021-02-02 11:02:20

React任務(wù)饑餓行為優(yōu)先級(jí)任務(wù)

2013-09-05 09:33:25

大數(shù)據(jù)盧東明SAP

2016-10-21 14:17:13

大數(shù)據(jù)技術(shù)大數(shù)據(jù)行為分析

2023-02-01 23:00:42

大數(shù)據(jù)

2024-04-18 08:30:00

留存分析模型數(shù)據(jù)分析

2024-09-19 15:22:24

2021-03-10 17:22:01

人臉識(shí)別人工智能數(shù)據(jù)

2022-03-25 12:22:01

行為風(fēng)險(xiǎn)分析網(wǎng)絡(luò)攻擊惡意軟件

2022-12-07 08:31:45

ClickHouse并行計(jì)算數(shù)據(jù)

2014-05-30 09:44:08

Android折紙動(dòng)畫

2013-03-28 13:51:19

Android設(shè)置全屏Android程序開發(fā)

2011-08-12 11:31:46

iPhoneUIView動(dòng)畫

2018-01-24 18:00:21

LinuxDebianvim

2017-05-02 10:30:46

2010-09-08 15:18:55

2009-02-04 10:30:47

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲xxxxx | 高清视频一区二区三区 | 在线观看国产www | 日韩精品在线网站 | 国产精品久久国产精品久久 | 久久91精品国产 | 成人国产精品视频 | 性色av一区二区三区 | 北条麻妃av一区二区三区 | 天堂资源 | 欧美日韩精品久久久免费观看 | 91人人在线| 91av免费看| 免费视频一区二区 | 一级看片免费视频囗交动图 | 91av在线免费 | 正在播放一区二区 | 一区二区三区免费 | 欧美精产国品一二三区 | 美国一级片在线观看 | 欧美成人精品一区二区三区 | 亚洲国产18 | 国产精品一区二区在线免费观看 | 亚洲成人免费视频在线 | 日日爱视频 | 福利视频网站 | 中文字幕在线第二页 | 国产午夜精品视频 | 国产成人一区在线 | 国产成人精品a视频一区www | 精品国产91亚洲一区二区三区www | 国产专区在线 | 久一精品 | 中文字幕 在线观看 | 亚洲a网| 久久久久久久久99 | 天天躁日日躁xxxxaaaa | 成人在线免费网站 | 国产一区二区三区四区五区加勒比 | 久久久国产精品一区 | 亚洲一区二区久久久 |