我用的XCode 版本是5
创建成功后,Xcode会自动生成必要的代码。我看到这些代码时,立刻联想到了 .net 的WinFrom工程的代码,很相似。
打开 main.m文件
#import <UIKit/UIKit.h> #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类的声明文件
#import <UIKit/UIKit.h> @interface AppDelegate : UIResponder <UIApplicationDelegate> @property (strong, nonatomic) UIWindow *window; @endAppDelegate继承自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; }
代码中,window的背景颜色是白色 [UIColor whiteColor] ,makeKeyAndVisible是让这个窗口可见,并显示到屏幕上。
执行流程示意
IOS Empty Application ,纯代码创建的视图应用程序,布布扣,bubuko.com
IOS Empty Application ,纯代码创建的视图应用程序
原文:http://blog.csdn.net/holdsky/article/details/22870629