//YJYAppDelegate.m

#import "YJYAppDelegate.h"

#import "YJYMasterViewController.h"

@implementation YJYAppDelegate

//@synthesize managedObjectContext = _managedObjectContext;的含义就是属性managedObjectContext的存取方法是做用于_managedObjectContext这个变量的。

//managedObjectContext是属性,而_managedObjectContext才是变量,我们最终操作的变量都是managedObjectContext。@synthesize managedObjectContext = _managedObjectContext;

@synthesize managedObjectModel = _managedObjectModel;

@synthesize persistentStoreCoordinator = _persistentStoreCoordinator;

//当由于其它方法打开应用程序(如URL指定或者连接),通知委托启动完毕

- (BOOL)application:(UIApplication *)appl

@implementation YJYAppDelegate

//@synthesize managedObjectContext = _managedObjectContext;的含义就是属性managedObjectContext的存取方法是做用于_managedObjectContext这个变量的。

//managedObjectContext是属性,而_managedObjectContext才是变量,我们最终操作的变量都是managedObjectContext。

@synthesize managedObjectContext = _managedObjectContext;

@synthesize managedObjectModel = _managedObjectModel;

@synthesize persistentStoreCoordinator = _persistentStoreCoordinator;

//当由于其它方法打开应用程序(如URL指定或者连接),通知委托启动完毕

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

NSLog(@"didFinishLaunchingWithOptions begin running()...");

// Override point for customization after application launch.

UISplitViewController *splitViewController = (UISplitViewController *)self.window.rootViewController;

UINavigationController *navigationController = [splitViewController.viewControllers lastObject];

splitViewController.delegate = (id)navigationController.topViewController;

UINavigationController *masterNavigationController = splitViewController.viewControllers[0];

YJYMasterViewController *controller = (YJYMasterViewController *)masterNavigationController.topViewController;

controller.managedObjectContication didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

NSLog(@"didFinishLaunchingWithOptions begin running()...");

// Override point for customization after application launch.

UISplitViewController *splitViewController = (UISplitViewController *)self.window.rootViewController;

UINavigationController *navigationController = [splitViewController.viewControllers lastObject];

splitViewController.delegate = (id)navigationController.topViewController;

UINavigationController *masterNavigationController = splitViewController.viewControllers[0];

YJYMasterViewController *controller = (YJYMasterViewController *)masterNavigationController.topViewController;

controller.managedObjectContext = self.managedObjectContext;

NSLog(@"didFinishLaunchingWithOptions() over...");

returnYES;

}

- (void)applicationWillResignActive:(UIApplication *)application

{// 通知委托应用程序将进入非活动状态,在此期间,应用程序不接收消息或事件,比如来电话了

NSLog(@"applicationWillResignActive() begin...over该方法没内容");

// Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.

// Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.

}

- (void)applicationDidEnterBackground:(UIApplication *)application

{//当程序被推送到后台的时候调用。所以要设置后台继续运行,则在这个函数里面设置即可

// Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.

// If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.

}

- (void)applicationWillEnterForeground:(UIApplication *)application

{//当程序从后台将要重新回到前台时候调用,这个刚好跟上面的那个方法相反。

// Called as part of the transition from the background to the inactive state; here you can undo many of the changes made on entering the background.

}

- (void)applicationDidBecomeActive:(UIApplication *)application

{//通知委托应用程序进入活动状态,请恢复数据

// Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.

}

//这个方法定义的是当应用程序退到后台时将执行的方法,按下home键执行(通知中心来调度)

//实现此方法的目的是将托管对象上下文存储到数据存储区,防止程序退出时有未保存的数据

- (void)applicationWillTerminate:(UIApplication *)application

{//当程序将要退出是被调用,通常是用来保存数据和一些退出前的清理工作。这个需要要设置

//applicationWillTerminate: 在程序结束前,Core Data会保存任何对其的更改

// Saves changes in the application's managed object context before the application terminates.

[selfsaveContext];

}

//相当与持久化方法

- (void)saveContext

{

NSError *error = nil;

NSManagedObjectContext *managedObjectContext = self.managedObjectContext;

if (managedObjectContext != nil) {

if ([managedObjectContext hasChanges] && ![managedObjectContext save:&error]) {

// Replace this implementation with code to handle the error appropriately.

// abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.

NSLog(@"Unresolved error %@, %@", error, [error userInfo]);

abort();

}

}

}

#pragma mark - Core Data stack

/*

先建立一个managedObjectModel,

然后根据 managedObjectModel 建立 persistentStoreCoordinator

然后根据 persistentStoreCoordinator 建立 managedObjectContext

然后是把managedObjectContext传给真正要使用数据的 viewcontroller

*/

// Returns the managed object context for the application.

// If the context doesn't already exist, it is created and bound to the persistent store coordinator for the application.

- (NSManagedObjectContext *)managedObjectContext

{//返回managedObjectContext对象

//自定义的managedObjectContext的getter, 它其实是真正在使用的时候的被操作对象

NSLog(@"managedObjectContext() begin...");

if (_managedObjectContext != nil) {//_managedObjectContext存在,直接返回

return_managedObjectContext;

}

//_managedObjectContext不存在,创建后返回

NSPersistentStoreCoordinator *coordinator = [selfpersistentStoreCoordinator];

if (coordinator != nil) {

_managedObjectContext = [[NSManagedObjectContextalloc] init];//创建一个_managedObjectContext对象

[_managedObjectContextsetPersistentStoreCoordinator:coordinator];

//这里可以看到,“内容管理器”和“数据一致性存储器”的关系,

//managedObjectContext需要得到这个“数据一致性存储器”

}

NSLog(@"managedObjectContext() over...");

return_managedObjectContext;

}

// Returns the managed object model for the application.

// If the model doesn't already exist, it is created from the application's model.

- (NSManagedObjectModel *)managedObjectModel

{//自定义的CoreData数据模板的getter,数据模板其实就是一个描述实体与实体的关系

//,类似于关系型数据库的关系描述文件

NSLog(@"managedObjectModel() begin....");

if (_managedObjectModel != nil) {

return_managedObjectModel;

}

NSURL *modelURL = [[NSBundlemainBundle] URLForResource:@"YJY"withExtension:@"momd"];//这里的URLForResource:@"YJY" 的url名字(YJY)要和你建立datamodel时候取的名字是一样的,至于怎么建datamodel很多教程讲的很清楚,扩展名是momd

_managedObjectModel = [[NSManagedObjectModelalloc] initWithContentsOfURL:modelURL];

NSLog(@"managedObjectModel() over...");

return_managedObjectModel;

}

// Returns the persistent store coordinator for the application.

// If the coordinator doesn't already exist, it is created and the application's store added to it.

- (NSPersistentStoreCoordinator *)persistentStoreCoordinator

{//自定义“数据一致性存储器” persistentStoreCoordinator的getter

NSLog(@"persistentStoreCoordinator() begin...");

if (_persistentStoreCoordinator != nil) {

return_persistentStoreCoordinator;

}

//定义一个本地地址到NSURL,用来存储那个SQLite文件

//这个地方的lich.sqlite名字没有限制,就是一个数据库文件的名字

NSURL *storeURL = [[selfapplicationDocumentsDirectory] URLByAppendingPathComponent:@"YJY.sqlite"];

NSError *error = nil;

_persistentStoreCoordinator = [[NSPersistentStoreCoordinatoralloc] initWithManagedObjectModel:[selfmanagedObjectModel]];

//从这里可以看出,其实persistentStoreCoordinator需要的不过是一个

//存储数据的位置,它是负责管理CoreData如何储存数据的

if (![_persistentStoreCoordinatoraddPersistentStoreWithType:NSSQLiteStoreTypeconfiguration:nilURL:storeURL options:nilerror:&error]) {// Handle the error.

/*

Replace this implementation with code to handle the error appropriately.

abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.

Typical reasons for an error here include:

* The persistent store is not accessible;

* The schema for the persistent store is incompatible with current managed object model.

Check the error message to determine what the actual problem was.

If the persistent store is not accessible, there is typically something wrong with the file path. Often, a file URL is pointing into the application's resources directory instead of a writeable directory.

If you encounter schema incompatibility errors during development, you can reduce their frequency by:

* Simply deleting the existing store:

[[NSFileManager defaultManager] removeItemAtURL:storeURL error:nil]

* Performing automatic lightweight migration by passing the following dictionary as the options parameter:

@{NSMigratePersistentStoresAutomaticallyOption:@YES, NSInferMappingModelAutomaticallyOption:@YES}

Lightweight migration will only work for a limited set of schema changes; consult "Core Data Model Versioning and Data Migration Programming Guide" for details.

*/

NSLog(@"Unresolved error %@, %@", error, [error userInfo]);

abort();

}

NSLog(@"persistentStoreCoordinator() over...");

return_persistentStoreCoordinator;

}

#pragma mark - Application's Documents directory

// Returns the URL to the application's Documents directory.

- (NSURL *)applicationDocumentsDirectory

{

//Documents目录路径,应用程序沙箱下的Documents目录路径

//返回该程序的档案目录,用来简单使用

NSLog(@"applicationDocumentsDirectory() begin...over");

return [[[NSFileManagerdefaultManager] URLsForDirectory:NSDocumentDirectoryinDomains:NSUserDomainMask] lastObject];

}

@end

最新文章

  1. maven的使用--初级篇
  2. 限制scrollView的上下移动
  3. jQqery EasyUI dategrid行中多列数据的可编辑操作
  4. thread_LockSupport
  5. Java继承中属性、方法和对象的关系
  6. bzoj 1012 [JSOI2008]最大数maxnumber
  7. CentOS系统安装JDK
  8. Codeforces Round #179 (Div. 1) A. Greg and Array 离线区间修改
  9. 选择排序SelectSort
  10. Linux crontab 命令格式与具体样例
  11. Asp.net 不安全端口 解决chrome浏览器访问时提示:ERR_UNSAFE_PORT
  12. A Simple Problem with Integers~POJ - 3468
  13. spring mvc 整合Quartz
  14. pytorch中文文档-torch.nn常用函数-待添加-明天继续
  15. 微信小程序里如何用阿里云上传视频,图片。。
  16. ejs常用功能函数
  17. P1843 奶牛晒衣服(二分)
  18. ListView中的组件Button的OnClick事件触发时机
  19. HDU 4283 You Are the One ——区间dp
  20. 浅表拷贝vs深度拷贝

热门文章

  1. ArcGIS发布地图服务
  2. 通配符+countif()解决大于15位数的计数问题
  3. Windows安装Python图像处理库:PIL模块
  4. SharePoint Web service and template
  5. IE中JavaScript 的异常处理
  6. addViewController之后view里面的点击事件不响应
  7. 在Handler.ashx文件中使用session
  8. 特征值提取之 -- TF-IDF值的简单介绍
  9. 智能手机Web开发笔记
  10. MapReduce 重要组件——Recordreader组件 [转]