我最近一直在努力改進我的知識和技能,對於過程中的應用程序的流程生命週期的各個點管理Android應用程序的狀態。具體來說,我一直在測試maintain and share global data between activities的各種方法。在我的測試應用程序中,爲了測試全球應用程序數據和/或單身數據的重新創建,我需要等待幾個小時或更長時間才能讓手機決定其他進程更重要,並將我的測試應用程序在process lifecycle documentation中定義的空進程狀態。此時,應用程序的數據被釋放,並且一旦應用程序再次被帶到前臺,需要重新創建。如果做得不正確,應用程序最後一次已知狀態的重新初始化可能會由於各種原因導致強制關閉。測試Android應用程序流程生命週期和恢復狀態當空進程到達狀態
所以,我的問題是,除了等着這個有機地發生,有測試此發生的真實世界的方式。例如,什麼樣的QA用例看起來像是測試應用程序進入後臺一段(非常)延長的時間,然後在應用程序達到空進程狀態時再次被帶到前臺?
我認爲強制關閉設置中的應用程序,或將應用程序滑出活動應用程序(長按主頁)不起作用? – bclymer
執行此類操作只會殺死應用程序,而不模仿操作系統如何管理文檔中描述的流程生命週期。例如,如果您在應用程序的活動#2中並且它進入了後臺。兩天後,當你再次打開應用程序時,操作系統已經摧毀了實際的應用程序進程。但保留的Empty進程狀態將嘗試以您離開它的相同狀態打開應用程序。在這種情況下,活動#2。如果狀態數據沒有妥善保留,可能會發生不好的事情。這些類型的場景是我對測試感興趣的。 – SBerg413