3 回答

TA貢獻1827條經驗 獲得超9個贊
我通常避免使用安德魯(Andrew)使用“應用程序的心臟”一詞所暗示的設計方法。我的意思是,我認為您應該避免將過多的內容混為一談-良好的程序設計通常涉及通過“關注區域”將功能分開。
委托對象是一個當其連接的對象達到某些事件或狀態時會得到通知的對象。在這種情況下,Application Delegate是一個對象,當UIApplication對象達到某些狀態時,它將接收通知。在許多方面,它是一種專門的一對一觀察者模式。
這意味著AppDelegate的“關注區域”正在處理特殊的UIApplication狀態。其中最重要的是:
applicationDidFinishLaunching:-非常適合處理啟動時的配置和構建
applicationWillTerminate:-適用于最后清理
您應該避免將其他功能放到AppDelegate中,因為它們并不真正屬于那里。這些其他功能包括:
文檔數據-您應該有一個文檔管理器單例(對于多個文檔應用程序)或一個文檔單例(對于單個文檔應用程序)
按鈕/表/視圖控制器,視圖委托方法或其他視圖處理(在applicationDidFinishLaunching:中頂級視圖的構造除外)—這項工作應在各自的視圖控制器類中進行。
許多人因為懶惰或認為AppDelegate控制著整個程序而將這些東西混入AppDelegate中。您應該避免集中在您的AppDelegate中,因為它會使應用程序中需要關注的領域變得混亂,并且無法擴展。

TA貢獻1811條經驗 獲得超5個贊
您的應用程序代表是您應用程序的核心。它實際上是您的“程序控制器”。
Application Delegate是接收應用程序級消息的類,其中包括最常用于啟動其他視圖創建的applicationDidFinishLaunching消息。
雖然不完全相似,但您可以將其視為Cocoa程序的“ main()”例程。

TA貢獻1830條經驗 獲得超3個贊
據我了解appDelegate
,它接近Application
Android。的viewDidLoad
,viewDidDisappear
相當于什么Android的生命周期。從啟動到呼叫中斷到顯示通知,每個應用程序都有生命周期。如果您需要代碼在這些system
事件發生時做一些特別的事情,那么您需要編寫方法的代碼。
在Android中,我們使用onPause
,onDestroy
,onCreate
還挺回調方法來處理這樣的系統事件。
- 3 回答
- 0 關注
- 908 瀏覽
添加回答
舉報