NSInteger page;
1.Property List
#define LIST_FILE_NAME @"Property.list" //Read - (void)restoreDataWithProperty { NSString *path = [self dataFilePathWithName:LIST_FILE_NAME]; if ([[NSFileManager defaultManager] fileExistsAtPath:path]) { NSArray *array = [[NSArray alloc] initWithContentsOfFile:path]; NSNumber *num = [array objectAtIndex:0]; page = [num integerValue]; } else { page = 1; } } //Write - (void)saveDataWithProperty { NSString *myFile = [self dataFilePathWithName:LIST_FILE_NAME]; NSMutableArray *array = [[NSMutableArray alloc] init]; NSNumber *num = [NSNumber numberWithInteger:page]; [array addObject:num]; [array writeToFile:myFile atomically:YES]; }
2.NSUserDefaults (Support Type:NSData,NSString,NSNumber,NSDate,NSArray,NSDictionary)
#define PAGE @"page" //Read - (void)restoreDataWithUserDefaults { NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults]; NSInteger p = [[defaults objectForKey:PAGE] integerValue]; if (0 == p) { page = 1; } else { page = p; } } //Write - (void)saveDataWithUserDefaults { NSUserDefaults *defaults = [NSUserDefaults standardUserDefaults]; NSNumber *num = [NSNumber numberWithInteger:page]; [defaults setObject:num forKey:PAGE]; [defaults synchronize]; }
3.Object Archive (Can save the Object data type, the Obejct must implement the NSCoding and NSCopying protocol)
#define ARCHIVE_FILE_PATH @"archive" #define NUMBER_KEY @"number" - (void)encodeWithCoder:(NSCoder *)aCoder{ NSLog(@"in encode with coder"); NSNumber *num = [[NSNumber numberWithInteger:self.page] autorelease]; [aCoder encodeObject:num forKey:NUMBER_KEY]; } - (id)initWithCoder:(NSCoder *)aDecoder { NSLog(@"in init with coder"); if (self = [super init]) { NSNumber *num = [aDecoder decodeObjectForKey:NUMBER_KEY]; page = [num integerValue]; } return self; } - (id)copyWithZone:(NSZone *)zone { NSLog(@"in copy with zone"); StickyNotesViewController *controller = [[[[self class] allocWithZone:zone] init] autorelease]; NSNumber *num = [[NSNumber numberWithInteger:self.page] autorelease]; controller.page = [[num copyWithZone:zone] integerValue]; return controller; } //Read - (void)restoreDataWithObjectArchive { NSString *path = [self dataFilePathWithName:ARCHIVE_FILE_PATH]; if ([[NSFileManager defaultManager] fileExistsAtPath:path]) { NSData *data = [[NSMutableData alloc] initWithContentsOfFile:path]; NSKeyedUnarchiver *unarchive = [[NSKeyedUnarchiver alloc] initForReadingWithData:data]; StickyNotesViewController *controller = [unarchive decodeObjectForKey:NUMBER_KEY]; [unarchive finishDecoding]; page = controller.page; } } //Write - (void)saveDataWithObjectArchive { StickyNotesViewController *controller = [[StickyNotesViewController alloc] init]; controller.page = self.page; NSMutableData *data = [[NSMutableData alloc] init]; NSKeyedArchiver *archive = [[NSKeyedArchiver alloc] initForWritingWithMutableData:data]; [archive encodeObject:controller forKey:NUMBER_KEY]; [archive finishEncoding]; [data writeToFile:[self dataFilePathWithName:ARCHIVE_FILE_PATH] atomically:YES]; }
4.Sqlite
#define SQLITE_DB_NAME @"my_data.db" //Read - (void)restoreDataWithSqlite { NSString *path = [self dataFilePathWithName:SQLITE_DB_NAME]; sqlite3 *database; int result = sqlite3_open([path UTF8String], &database); if (SQLITE_OK != result) { sqlite3_close(database); NSAssert(0, @"Failed to open database"); } char *errorMsg; char *createTable = "CREATE TABLE IF NOT EXISTS LX(ROW INTEGER PRIMARY KEY, DATA INTEGER);"; int result2 = sqlite3_exec(database, createTable, NULL, NULL, &errorMsg); if (SQLITE_OK != result2) { sqlite3_close(database); NSAssert(0, @"Failed to create the table: %s", errorMsg); } char *query = "SELECT ROW, DATA FROM LX ORDER BY ROW"; sqlite3_stmt *stmt; int result3 = sqlite3_prepare_v2(database, query , -1, &stmt, nil); if (SQLITE_OK == result3) { while (sqlite3_step(stmt) == SQLITE_ROW) { int row = sqlite3_column_int(stmt, 0); int data = sqlite3_column_int(stmt, 1); page = data; NSLog(@"row=%d ,data=%d",row, data); } sqlite3_finalize(stmt); } sqlite3_close(database); } //Write - (void)saveDataWithSqlite { sqlite3 *database; int result = sqlite3_open([[self dataFilePathWithName:SQLITE_DB_NAME] UTF8String], &database); if (result != SQLITE_OK) { sqlite3_close(database); NSLog(@"Failed open the database"); NSAssert(0, @"Failed to open the database"); } char *update = "INSERT OR REPLACE INTO LX VALUES(?, ?);"; sqlite3_stmt *stmt; int result2 = sqlite3_prepare_v2(database, update, -1, &stmt, nil); if (result2 == SQLITE_OK) { sqlite3_bind_int(stmt, 1, 1); sqlite3_bind_int(stmt, 2, page); } else { NSLog(@"Failed to prepare statement"); NSAssert1(0, @"error msg: %s", sqlite3_errmsg(database)); } int result3 = sqlite3_step(stmt); if (SQLITE_DONE != result3) { NSAssert1(0, @"Error updating table: %d", result3); } sqlite3_finalize(stmt); sqlite3_close(database); }
//get file path by name - (NSString *)dataFilePathWithName:fileName { NSArray *path = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); NSString *docPath = [path objectAtIndex:0]; NSString *myFile = [docPath stringByAppendingPathComponent:fileName]; if ([[NSFileManager defaultManager] fileExistsAtPath:myFile]) { } else { //[[NSFileManager defaultManager] createFileAtPath:myFile contents:nil attributes:nil]; } return myFile; }
以下关于sqlite3的讲解内容转自
http://blog.csdn.net/m_changgong/article/details/8284135 作者:张燕广
注1:sqlite3_open():打开数据库
在操作数据库之前,首先要打开数据库。
这个函数打开一个sqlite数据库文件的连接并且返回一个数据库连接对象。
第1个参数:数据文件路径必须用C风格字符串(不能用NSString),[filePath UTF8String]将filePath转换为C风格字符串。
第2个参数:是返回的数据库连接对象。
这个过程销毁前面被sqlite3_prepare创建的准备语句,每个准备语句都必须使用这个函数去销毁以防止内存泄露。
在空指针上调用这个函数没有什么影响,同时可以在准备语句的生命周期的任一时刻调用这个函数:在语句被执行前,一次或多次调用
sqlite_reset之后,或者在sqlite3_step任何调用之后。
备注7:sqlite3_close()
关闭前面使用sqlite3_open打开的数据库连接,任何与这个连接相关的准备语句必须在调用这个关闭函数之前被释放掉。
备注8:sqlite3_bind_text()
第1个参数:指向在sqlite3_prepare_v2()调用中使用的sqlite3_stme。
第2个参数:所绑定的变量的索引(sql语句中第一个问号的索引),需要注意的是:第一个问号的索引是1,而不是0。
第3个参数:只有少数绑定函数,比如用于绑定文本或二进制数据的绑定函数,这个参数用来设定传递数据的长度。对于C字符串,可以传递-1来代替字符串的长度,意思是要是要使用整个字符串。
第4个参数:回调函数,一般用于在语句执行后做内存清理相关的工作。可以设置为NULL。