我的第一个iphonet小程序诞生!

前端之家收集整理的这篇文章主要介绍了我的第一个iphonet小程序诞生!前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

经过一周的时间,终于完成了我的第一个iphone程序,暂时出名叫PocketWord,简称PW。它是一个简单的单词手册程序,目前功能是:可以开关单词解释,当关闭单词解释时,被选择单词会显示涵义。

上面是程序的界面,非常的简单,但还是在使用sqlite3时费了我不少周折,现在总结一下完成这个程序中遇到的问题,做个纪念。

单词都是放在sqlite3数据库文件中的,在xcode中使用的#import <sqlite3.h>导入头文件,以C函数的形式调用使用。

问题1. 导入sqlite3动态连接库

在做PW程序之前,还专门用sqlite3做了一个控制台程序,就遇到编译问题,后来才知道xcode中使用sqlite3还需要导入libsqlite3.dylib动态连接库文件查询一翻找到“/Developer/SDKs/MacOSX10.6.sdk/usr/lib/libsqlite3.dylib” 文件导入工程中,程序也顺利编译通过。待到做PW程序时,之前是在模拟器中调试运行都还一切正常。正在高兴之时,设置为真机运行时提示link错误.

提示的信息上看,是sqlite3在连接上出的问题。还好在网络上cocoachina论坛上找到同样问题的帖子,才解决决问题。

问题原因是在iphone中使用的libsqlite3.dylib与在mac上的文件不一样。在iphone上需要导入:

“/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS4.3.sdk/usr/lib/libsqlite3.dylib"目录下的动态连接文件

后来发现在xcode中可以直接导入,非常方便,免得到目录中去找。具体方法是:

选择project->TARGETS->BuildPhases->LinkBinaryWith Libraries 点击加号,在弹出的窗口中选择sdk提供的动态库就是了。

还是看图简单一点:

问题2. 数据库文件的存放,与复制。

sqlite3动态连接问题前,在模拟器中运行的时候还遇到一个问题,就是在使用sqlite3_prepare_v2函数执行SQL查询时总是返回1,意思是表不存在,但调试打开数据库是正常的。我又反复在终端上使用sqlite3命令行程序反复验证过sql是对的,表是也是有的。分析了一下: 1.sqlite在使用上不对; 2.要不就是数据库文件不对. 我在打开数据库之前使用代码检查一下db文件是否存,打印出文件大小:

//取得document路径数组
 NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDirectory,YES);
 //取得一个为当前程序的document目录
 NSString *documentDirectory = [pathsobjectAtIndex:0];
 //组装db文件名。
 self.dbFileName = [documentDirectorystringByAppendingPathComponent:@"vocabulary.db"];

 if (self.dbFileName == nil) //文件不存在退出
    return;
 //创建文件管理器
  NSFileManager *fileManager = [NSFileManagerdefaultManager];
 //取得文件属性,返回一个字典对象
 NSDictionary * attributes = [fileManagerattributesOfItemAtPath:self.dbFileName
                              error:nil];
 //从字典里查询NSFileSize,取文件大小
 NSNumber *theFileSize = [attributesobjectForKey:NSFileSize];
 NSLog(@"%dbfile: @,size: %d",self.dbFileName,theFileSize);
 if(theFileSize == 0)
    return;

调试程序发现,我的db文件大小为0,这是因为sqlite3_open函数在发现指定的文件不存在时,会自动生成。我的db文件不documneth目录下,必使用代码将使用到的资源文件拷贝到document下

  //使用NSBundle来取得工程中的db文件路径。
  NSString *dbFile = [NSBundle mainBundle] pathForResource:@"vocabulary"ofType:@"db"]; 
  [fileManager copyItemAtPath: dbFiletoPath: self.dbFileName error:nil];
至此才将db文件复制到环境下,数据库问题终于解决了。

猜你在找的Sqlite相关文章