Windows?Phone 執行模型控制在 Windows?Phone 上運行的應用程序的生命周期,該過程從啟動應用程序開始,直至應用程序終止。
該執行模型旨在始終為最終用戶提供快速響應的體驗。為此,在任何給定時間內,Windows?Phone 僅允許一個應用程序在前臺運行。當應用程序不再運行于前臺時,操作系統將使應用程序進入休眠狀態。如果可用于前臺應用程序的設備內存不足,無法提供出色的用戶體驗,則操作系統將開始終止休眠的應用程序(首先終止最早使用的應用程序)。應用程序可以使用為其提供的編程框架在取消激活和重新激活時管理其狀態。這有助于創建一種在用戶看來應用程序保持單一實例的用戶體驗,即使應用程序已終止或已重新激活。
該執行模型還為用戶提供了應用程序間一致的導航體驗。在 Windows?Phone 中,用戶可通過從已安裝程序列表或從“開始”中的磁貼啟動應用程序來向前導航,除此之外,還可以通過其他方式向前導航,如點按與應用程序相關的 Toast 通知。用戶還可以使用硬件“返回”按鈕向后導航各個運行應用程序的頁面,或者向后導航先前運行的應用程序的堆棧。Windows?Phone?7.5 添加了通過按住硬件“返回”按鈕來切換到先前運行的應用程序的功能。
?
Windows Phone 應用程序生命周期
下圖演示了 Windows?Phone 應用程序的生命周期。在該圖中,圓圈表示應用程序的狀態。矩形顯示應用程序應管理其狀態的應用程序級別或頁面級別的事件。
?
?
? ? ? ? ?
Launching 事件
launchings事件在用戶從已安裝程序列表或從“開始”中的磁貼或通過其他方式(如點按與應用程序相關的 Toast 通知或從“Photos Extras”菜單中選擇應用程序)啟動新的應用程序實例時引發。當以此方式啟動應用程序時,它應向用戶顯示新實例,而不是先前實例的延續。為了幫助確保應用程序快速加載,應在該事件的處理程序中執行盡可能少的代碼。特別是,避免文件和網絡操作等資源密集型任務。您應在應用程序加載之后,在后臺線程中執行這些任務以便實現最佳的用戶體驗。
運行
啟動之后,應用程序處于運行狀態。在用戶向前導航、離開應用程序或向后導航到第一個應用程序頁面之前,應用程序程序將持續運行。Windows?Phone 應用程序不應為用戶提供退出應用程序的機制。當手機的鎖定屏幕功能啟動時,應用程序將保持運行狀態,除非您已禁用應用程序空閑檢測。有關更多信息,請參閱?Windows Phone 空閑檢測。
OnNavigatedFrom 方法
當用戶導航離開應用程序頁面時,將會調用?OnNavigatedFrom(NavigationEventArgs)?方法。這可能是由應用程序中的普通頁面導航導致。當取消激活應用程序時也會調用該方法,下一節將對此進行討論。每當調用該方法時,應用程序都應存儲頁面的狀態,以便在用戶返回到頁面時可以還原應用程序。向后導航除外。可以使用?NavigationMode?屬性來確定導航是否為向后導航,若為向后導航,則無需保存狀態,因為頁面將在下次訪問時重新。在某些情況下,您可能希望將狀態同時保存在?OnNavigatingFrom(NavigatingCancelEventArgs)?方法中。尤其是在存儲?MediaElement?控件的狀態時,您將需要執行此操作。
Deactivated 事件
當用戶向前導航、導航出您的應用程序、按“開始”按鈕或啟動其他應用程序時,都將會引發?Deactivated?事件。如果您的應用程序啟動選擇器,也會引發?Deactivated?事件。有關選擇器的更多信息,請參閱?Windows Phone 啟動器和選擇器概述。當設備的鎖定屏幕功能啟動時,也會引發該事件,除非已禁用應用程序空閑檢測。
在?Deactivated?事件的處理程序中,您的應用程序應保存任何應用程序狀態,以便將來還原。Windows?Phone 應用程序隨?State?對象一起提供,后者是可以用來存儲應用程序狀態的字典。如果應用程序在被邏輯刪除后重新激活,則將使用您保存在?Deactivated?中的數據填充該狀態字典。由于內存中存在該數據,您可以用它來還原狀態,而無需資源密集型的文件操作。
在調用?Deactivated?后,應用程序可能會被完全終止。當應用程序終止時,其狀態將不保留。因此,還應在?Deactivated?事件期間,將應用程序實例間應保留的所有未保存狀態存儲到獨立存儲中。
休眠
當用戶向前導航或導航出應用程序時,引發?Deactivated?事件后,操作系統將嘗試使應用程序置于休眠狀態。在此狀態下,應用程序的所有線程均將停止,并且不進行任何處理操作,但應用程序仍完好地保留在內存中。如果從該狀態中重新激活應用程序,應用程序無需重新創建任何狀態,因為狀態已保留。
如果在應用程序進入休眠狀態后啟動新的應用程序,這些應用程序需要更多的內存才能提供出色的用戶體驗,操作系統將開始邏輯刪除休眠的應用程序以釋放內存。
已邏輯刪除
邏輯刪除的應用程序已終止,但該應用程序的導航狀態相關信息和?Deactivated?期間由應用程序填充的狀態字典將保留下來。設備每次最多可維護五個應用程序的邏輯刪除信息。如果在邏輯刪除應用程序之后,用戶向后導航至應用程序,則應用程序將會重新啟動并使用保留的數據還原狀態。否則,將只是終止應用程序。
Activated 事件
當用戶返回到休眠或邏輯刪除的應用程序時,將調用?Activated?事件。應用程序應檢查事件參數的?IsApplicationInstancePreserved?屬性,以確定應用程序是從休眠狀態返回,還是從邏輯刪除狀態返回。如果IsApplicationInstancePreserved?為 true,則應用程序之前處于休眠狀態,狀態已由操作系統自動保留。若為 false,則應用程序之前已被邏輯刪除,應用程序應使用狀態字典來還原應用程序狀態。在執行?Activated?事件處理程序期間,應用程序不應執行資源密集型任務(例如,從獨立存儲或網絡資源加載內容),因為這會增加應用程序恢復所用的時間。而是應在加載應用程序之后,在后臺線程中執行這些操作。
OnNavigatedTo 方法
當用戶導航到頁面時,即會調用?OnNavigatedTo(NavigationEventArgs)?方法。這包括當應用程序第一次啟動時、用戶在應用程序的頁面之間進行導航時以及在應用程序休眠或被邏輯刪除后重新啟動時。在此方法中,應用程序應檢查是否頁面為新實例。若不是新實例,則無需還原。若頁面為新實例,并且在頁面的狀態字典中存在數據,則應使用該數據來還原頁面 UI 的狀態。
Closing 事件
當用戶向后導航到應用程序的第一頁時,即會引發?Closing?事件。在這種情況下,應用程序將終止,并且不會保存狀態。在?Closing?事件處理程序中,您的應用程序可以保存應跨實例保留的數據。應用程序完成所有應用程序和頁面導航事件的時間被限定為 10 秒。若超出此限度,則應用程序將終止。因此,最好保存整個應用程序生存期的持續狀態,避免在?Closing?事件處理程序中執行大量的文件 I/O 操作。
?
執行模型事件和應用程序操作摘要
下表是應用程序生命周期內所發生事件和應用程序應針對每個事件執行的操作的簡短摘要。
事件或方法 | 應用程序操作 |
---|---|
Launching 事件 | 執行非常少量的代碼。不要執行資源密集型操作,例如,訪問獨立存儲。 |
OnNavigatedFrom 方法 | 如果不是向后導航,則將 UI 狀態保存到?State?字典。 |
Deactivated 事件 | 當應用程序被邏輯刪除時,將應用程序狀態保存到?State。同時,在應用程序終止時,將持續狀態保存到獨立存儲。當應用程序進入休眠狀態時,不要銷毀內存中應用程序的狀態。 |
Activated 事件 | 檢查?IsApplicationInstancePreserved。若為 true,則不執行任何操作。若為 false,則使用?State?中的數據還原應用程序狀態。 |
OnNavigatedTo 方法 | 檢查頁面是否為新實例。若不是,則狀態自動保持。否則,如果?State?中存在數據,則使用該數據還原 UI。 |
Closing 事件 | 將持續應用程序數據保存到獨立存儲。 |
![]() |
---|
通過本節所述的事件,您可以在應用程序進入和離開前臺時保存和還原狀態。但是,推薦的做法是在狀態數據發生更改時立即保存狀態數據。例如,當收到來自網絡的某個 Web 請求時,可以立即將其結果保存到磁盤和/或應用程序狀態字典中。您不應等到?Deactivated?事件發生后才存儲此數據。請記住,所有應用程序生命周期事件都強制限定應用程序在 10 秒鐘的時間內完成所有任務。 |