我用的XCode 版本是5
建立個ios工程,選Empty Application
<喎?http://www.bkjia.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+tLS9qLPJuaa686OsWGNvZGW74dfUtq/J+rPJsdjSqrXEtPrC66GjztK/tLW91eLQqbT6wuvKsaOswaK/zMGqz+u1vcHLIC5uZXQgtcRXaW5Gcm9tuaSzzLXEtPrC66OsutzP4CYjMjAyODQ7oaMgIDxicj4KPC9wPgo8cD48YnI+CjwvcD4KPGgzPlVJQXBwbGljYXRpb25NYWluPGJyPgo8L2gzPgo8cD608r+qICBtYWluLm3OxLz+PC9wPgo8cD48L3A+CjxwcmUgY2xhc3M9"brush:java;">#import #import "AppDelegate.h" //AppDelegate的名字可以更改,我使用的是預設的。int main(int argc, char * argv[]){ @autoreleasepool { return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class])); }}看到了我們再熟悉不過的main函數了。Object-C承襲了C的這個main入口函數特性。當我們啟動ios用程式時,運行時將準備工作做好後,就執行main函數。
上面的代碼中,除去@autoreleasepool指令,main函數體只有一行代碼。
return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
這行代碼還直接return了,那麼可以推斷UIApplicationMain函數裡面執行了某種“死迴圈”,才能讓應用程式運行到這行代碼不會立刻結束。這種“死迴圈”和windows的訊息迴圈是類似的。
注意UIApplicationMain函數的第4個參數,NSStringFromClass([AppDelegate class]),是個字串值,也就是你完全可以用@“AppDelegate”常量字串代替它
return UIApplicationMain(argc, argv, nil, @"AppDelegate" );
UIApplicationMain會使用反射建立AppDelegate類的執行個體。
更多的關於"UIApplicationMain介紹"。
委託類AppDelegate
開啟AppDelegate類的聲明檔案
#import @interface AppDelegate : UIResponder @property (strong, nonatomic) UIWindow *window;@end
AppDelegate繼承自UIResponder,遵從UIApplicationDelegate協議。UIApplicationMain便是通過UIApplicationDelegate協議和AppDelegate通訊。
AppDelegate有個類型為UIWindow*成員的window。
開啟AppDelegate類的實現檔案,裡面有UIApplicationDelegate協議的預設實現。
其中,didFinishLaunchingWithOptions實現裡面
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions{ self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]]; // Override point for customization after application launch. self.window.backgroundColor = [UIColor whiteColor]; [self.window makeKeyAndVisible]; return YES;}
可以看到,AppDelegate執行個體的window成員這裡進行初始化。一般的,window視窗應該是ios應用程式的第一個視窗視圖。
代碼中,window的背景顏色是白色 [UIColor whiteColor] ,makeKeyAndVisible是讓這個視窗可見,並顯示到螢幕上。
執行流程示意