常見問題2016/08/30

【APP開發】android ANR異常及其解決方式

ANR定義

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

解決ANR異常概述:   

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

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

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

引起ANR異常的常見情況:

1、在主執行緒內進行網路操作,獲取伺服器上的資源

2、在主執行緒內進行一些緩慢的磁碟操作(

      應用應該在5秒或者10秒內響應

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

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

通過Handler解決ANR異常:

方式一:

1.開啟一個新的執行緒,進行資料請求,此執行緒內包含了比較耗時操作的程式碼
2. 獲取資料後,呼叫handler.sendMessage方法
3. 在主執行緒中呼叫  handleMessgae(Message msg) 方法接收資料並更新UI

方式二:

利用handler.post(new Runnable(){

              public void run(){

             ——————– 耗時操作的程式碼

           }}

        );

給建立handler物件的執行緒傳送一個runnable,自動執行run方法

 

本文來自新浪部落格