ANR

ANR

在Android上,如果你的應用程式有一段時間回響不夠靈敏,系統會向用戶顯示一個對話框,這個對話框稱作應用程式無回響(ANR:Application Not Responding)對話框。用戶可以選擇“等待”而讓程式繼續運行,也可以選擇“強制關閉”。所以一個流暢的合理的應用程式中不能出現anr,而讓用戶每次都要處理這個對話框。因此,在程式里對回響性能的設計很重要,這樣系統不會顯示ANR給用戶。默認情況下,在android中Activity的最長執行時間是5秒,BroadcastReceiver的最長執行時間則是10秒。

ANR 定義

ANR(Application Not Responding)定義

在Android上,如果你的應用程式有一段時間回響不夠靈敏,系統會向用戶顯示一個對話框,這個對話框稱作應用程式無回響(ANR:Application Not Responding)對話框。用戶可以選擇“等待”而讓程式繼續運行,也可以選擇“強制關閉”。所以一個流暢的合理的應用程式中不能出現anr,而讓用戶每次都要處理這個對話框。因此,在程式里對回響性能的設計很重要,這樣系統不會顯示ANR給用戶。默認情況下,在android中Activity的最長執行時間是5秒,BroadcastReceiver的最長執行時間則是10秒。

如何來避免:

考慮上面的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或者快速顯示主畫面並異步來填充這些信息。在這兩種情況下,你都應該顯示正在進行的進度,以免用戶認為應用程式被凍結了。

ANR 技術

ANR(Automatic Network Replenishment Technology)

對視頻監控來說,存儲性能的重要性幾乎與圖像質量是一樣的。傳統DVR已經積累了不少先進的技術,如硬碟零碎片處理、硬碟輪休、異常斷電保護等技術,為監控圖像的可靠存儲提供有力保障,NVR作為新一代網路監控產品,首先對DVR優秀的特性作了全面繼承,其次它還藉助網路化特性,進一步提升了存儲的可靠性與靈活性,這其中最有意義的就是ANR技術的套用。我們知道,NVR的基礎是網路,但網路承載業務的複雜性較高,導致了網路的不穩定,因此直接影響了承載於上的業務的穩定性。並且,這一點對於視頻監控是絕對不容輕視的,因為可能由於網路的暫時性故障會直接導致重要視頻錄像的缺失,而錄像資料之於視頻監控的重要性絕對是首當其衝的。因此,網路不穩定導致錄像資料的遺失這一點也一度成為NVR對峙DVR決戰中最具致命性的隱患,但ANR技術的套用卻使一切問題不復存在。

ANR,Automatic Network Replenishment Technology,它是一種結合本地存儲和網路存儲的技術,ANR技術包括三個部分:一、偵測網路狀況,即在網路失效時,能記錄下失效前的傳輸數據,以待網路連結恢復後把數據轉回到管理中心;二、雙重錄像,即當網路出現問題或不穩定時,管理中心和前端雙方都會把圖像數據單獨存儲在緩衝區以作備份;三、自動修複數據,即當網路恢復正常後,管理中心和前端雙方會對比各自的數據,檢查對比在網路失效時的圖像數據,然後自動修復管理中心錯誤或遺失的數據。據此就可明白,具備ANR技術的NVR會在網路出現故障時自動啟用前端存儲,網路恢復後再將前端存儲數據自動同步至NVR中心,並且是在不影響實時視頻傳輸質量的前提下,從而實現了中心與前端的雙存儲備份,有效提升存儲的可靠性與靈活性。

此外,針對一些對存儲有著更高要求的場合,NVR還將提供另一項存儲保障技術——RAID存儲。雖然RAID的套用會導致用戶使用成本的提高,但由於它的可靠性機制可以確保硬碟的有效合理使用、實現數據的冗餘校驗,使圖像數據即使在部分存儲介質損壞的情況下也不會丟失等重要性能,從而使得這一技術在對監控系統性能要求極高的高端行業市場一直受到重視,因此RAID技術的套用必然也會促進NVR對新市場的拓展,進一步加快取代DVR的進程。

相關搜尋

熱門詞條

聯絡我們