我用的XCode 版本是5
上面的代碼中,除去@autoreleasepool指令,main函數體只有一行代碼。 注意UIApplicationMain函數的第4個參數,NSStringFromClass([AppDelegate class]),是個字符串值,也就是你完全可以用@“AppDelegate”常量字符串代替它 更多的關於"UIApplicationMain介紹"。 打開AppDelegate類的聲明文件 AppDelegate有個類型為UIWindow*成員的window。 打開AppDelegate類的實現文件,裡面有UIApplicationDelegate協議的默認實現。 其中,didFinishLaunchingWithOptions實現裡面 代碼中,window的背景顏色是白色 [UIColor whiteColor] ,makeKeyAndVisible是讓這個窗口可見,並顯示到屏幕上。 執行流程示意
<喎?/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHA+tLS9qLPJuaa686OsWGNvZGW74dfUtq/J+rPJsdjSqrXEtPrC66GjztK/tLW91eLQqbT6wuvKsaOswaK/zMGqz+u1vcHLIC5uZXQgtcRXaW5Gcm9tuaSzzLXEtPrC66OsutzP4CYjMjAyODQ7oaMgIDxicj4KPC9wPgo8cD48YnI+CjwvcD4KPGgzPlVJQXBwbGljYXRpb25NYWluPGJyPgo8L2gzPgo8cD608r+qICBtYWluLm3OxLz+PC9wPgo8cD48L3A+CjxwcmUgY2xhc3M9"brush:java;">#import return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
這行代碼還直接return了,那麼可以推斷UIApplicationMain函數裡面執行了某種“死循環”,才能讓應用程序運行到這行代碼不會立刻結束。這種“死循環”和windows的消息循環是類似的。
return UIApplicationMain(argc, argv, nil, @"AppDelegate" );
UIApplicationMain會使用反射創建AppDelegate類的實例。
委托類AppDelegate
#import
AppDelegate繼承自UIResponder,遵從UIApplicationDelegate協議。UIApplicationMain便是通過UIApplicationDelegate協議和AppDelegate通信。
- (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應用程序的第一個窗口視圖。