Android中進程額重要性等級劃分

Android系統會儘可能時間長的來維持一個程序的進程,但當系統資源緊張的時候,系統終究會爲一些新的或者更重要的進程殺死一些舊的進程來釋放內存。系統主要是根據進程中組件的運行狀態,來決定每一個進程的重要性,從而決定哪個進程需要殺死,哪個進程需要保持。最不重要的進程最容易先被殺死,其次最不重要的進程會被殺死,以此往復,直到系統恢復了需要的資源。
既然系統主要根據進程的重要性來決定一個進程的存亡,下面我們就將介紹根據重要性分類的五種不同進程(重要性由高到低)。
1.foreground process,前臺進程
所謂前臺進程就是指用戶完成當前工作而需要的進程。判斷條件如下(滿足其一即可):
-進程中的某個Activity正在與用戶進行交互(Activity的onResume()方法被調用)
-綁定到與當前用戶正在交互的activity的Service所在的進程
-進程中的某個Service正運行在前臺,即這個service的startForeground()方法被調用
-進程中的某個Service正在執行生命週期回調方法(比如,onCreate(),onStart(),或者onDeatroy())
-進程中的BroadcastReceiver正在執行onReceive()方法。

一般來說的話,在某特定時刻,也僅會有爲數不多的幾個前臺進程。這些前臺進程的重要性最高,當系統內存低到很低,以致不能繼續運行這些所有的進程的話,系統將會殺死這些進程。這種情況下,一般是指系統已經到了一個極限邊緣了,所以爲了讓UI繼續有反應的話,系統不得不殺死一些前臺進程。


2.可視進程-visible process

可視進程是指沒有前臺運行的組件,但仍然會對用戶在屏幕看到的內容造成影響的進程。滿足下面條件的進程都可以算作可視進程:
-進程運行的Activity不在前臺,但仍然是可見的(調用了onPause()方法)。這種情況可能是這樣的,正在前臺運行的Activity啓動了一個對話框,這個對話框懸浮在這個activity之上,但仍有部分可見。
-進程中的Service綁定到了一個可視(或前臺)的activity(該activity已調用了onPause()方法)。

可視進程也是有着極高重要性的進程,只有在系統爲了保持前臺進程運行而不得不殺死可視進程的時候,纔會殺死可視進程。


3.服務進程-service process

所謂的服務進程,就是指除了上面兩種進程外,如果一個進程已經通過startService()方法啓動了一個service的進程。雖然這種service進程跟用戶的看到的內容不相關,但它們所做的工作也是用戶關心的(比如在後臺播放音樂或者正在下載互聯網上的資源),系統會一直保持服務進程,除非系統爲了前臺進程和可視進程的運行,而不得不殺死服務進程。


4.後臺進程-background process

後臺進程是指進程中的activity當前對用戶來說不可見(這個activity調用了onStop()方法)。後臺進程不會對用戶的體驗造成任何影響,並且系統可以在前臺進程、可視進程、服務繼承需要內存資源的時候會殺死後臺進程。通常會有很多後臺進程運行,並且這些後臺進程保存在一個最近使用列表中,這樣做的好處就是保證用戶最近看到的進程最後被殺死。如果一個activity已經正確的實現了生命週期方法,並且保存了當前的狀態,那麼系統殺死這些後臺進程對用戶的可視效果來說的話,沒有任何影響,因爲當用戶返回回來的時候,這個activity已經保存了所有的可視狀態。


5.空進程-empty process
一個空進程沒有任何運行的程序組件。系統保持空進程存在的唯一原因就是爲了緩存方面的考慮,這樣做主要是爲了提高組件的啓動時間。系統經常會殺死這些空進程來保持整個系統資源和內核緩存之間的平衡。
Android根據進程中運行的最重要的組件進行劃分進程的重要性,比如說,如果一個進程中即有一個可視的activity,又有一個service,那麼這個進程應該屬於可視進程而不是服務進程。

另外,一個進程的重要性等級可能會因爲依賴於該進程的其他進程而提高——一個服務於其他進程的重要性不會低於被服務的進程。比如說,進程A中的一個content provider正在爲進程B中的客戶服務,或者進程A中的一個service被綁定到了進程B中的一個組件,那麼進程A的重要性至少會被認爲是和B的重要性是一樣的。


因爲一個正在運行的服務所在的進程的重要性高於一個處於後臺的activity所在的進程,所以根據這一點,如果一個activity如果要執行需要長時間運行的操作的話,這個activity最好爲該操作啓動一個新的服務,而不是僅僅創建一個工作線程,尤其是當這個工作線程運行的時間可能比該activity的運行時間還長的時候。比如說,如果一個activity要往一個網站上上傳一張圖片的話,這個activity就應該啓動一個服務來完成這個上傳操作,這要做的好處就是即使用戶離開了當前的這個activity,上傳服務還會繼續進行。使用一個服務保證一個進程至少還有服務進程這個優先級,而不用擔心activity會發生什麼情況。這也正是爲什麼廣播接收者應該使用服務而不是把耗時的操作放在一個線程中的原因。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章