Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發實例 >> 什麼是ANR 如何避免它?

什麼是ANR 如何避免它?

編輯:Android開發實例

ANR定義

     在Android上,如果你的應用程序有一段時間響應不夠靈敏,系統會向用戶顯示一個對話框,這個對話框稱作應用程序無響應(ANR:Application Not Responding)對話框。用戶可以選擇讓程序繼續運行,但是,他們在使用你的應用程序時,並不希望每次都要處理這個對話框。因此,在程序裡對響應性能的設計很重要,這樣,系統不會顯示ANR給用戶。

    如何來避免:

考慮上面的ANR定義,讓我們來研究一下為什麼它會在Android應用程序裡發生和如何最佳構建應用程序來避免ANR。

Android應用程序通常是運行在一個單獨的線程(例如,main)裡。這意味著你的應用程序所做的事情如果在主線程裡占用了太長的時間的話,就會引發ANR對話框,因為你的應用程序並沒有給自己機會來處理輸入事件或者Intent廣播。

因此,運行在主線程裡的任何方法都盡可能少做事情。特別是,Activity應該在它的關鍵生命周期方法(如onCreate()和onResume())裡盡可能少的去做創建操作。潛在的耗時操作,例如網絡或數據庫操作,或者高耗時的計算如改變位圖尺寸,應該在子線程裡(或者以數據庫操作為例,通過異步請求的方式)來完成。然而,不是說你的主線程阻塞在那裡等待子線程的完成——也不是調用Thread.wait()或是Thread.sleep()。替代的方法是,主線程應該為子線程提供一個Handler,以便完成時能夠提交給主線程。以這種方式設計你的應用程序,將能保證你的主線程保持對輸入的響應性並能避免由於5秒輸入事件的超時引發的ANR對話框。這種做法應該在其它顯示UI的線程裡效仿,因為它們都受相同的超時影響。

IntentReceiver執行時間的特殊限制意味著它應該做:在後台裡做小的、瑣碎的工作如保存設定或者注冊一個Notification。和在主線程裡調用的其它方法一樣,應用程序應該避免在BroadcastReceiver裡做耗時的操作或計算。但不再是在子線程裡做這些任務(因為BroadcastReceiver的生命周期短),替代的是,如果響應Intent廣播需要執行一個耗時的動作的話,應用程序應該啟動一個Service。順便提及一句,你也應該避免在Intent Receiver裡啟動一個Activity,因為它會創建一個新的畫面,並從當前用戶正在運行的程序上搶奪焦點。如果你的應用程序在響應Intent廣播時需要向用戶展示什麼,你應該使用Notification Manager來實現。

一般來說,在應用程序裡,100到200ms是用戶能感知阻滯的時間阈值。因此,這裡有一些額外的技巧來避免ANR,並有助於讓你的應用程序看起來有響應性。

如果你的應用程序為響應用戶輸入正在後台工作的話,可以顯示工作的進度(ProgressBar和ProgressDialog對這種情況來說很有用)。

特別是游戲,在子線程裡做移動的計算。

如果你的應用程序有一個耗時的初始化過程的話,考慮可以顯示一個Splash Screen或者快速顯示主畫面並異步來填充這些信息。在這兩種情況下,你都應該顯示正在進行的進度,以免用戶認為應用程序被凍結了。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved