加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-12 20:41:23 所属栏目:百科 来源:网络整理
导读:经过一周的时间,终于完成了我的第一个iphone程序,暂时出名叫PocketWord,简称PW。它是一个简单的单词手册程序,目前功能是:可以开关单词解释,当关闭单词解释时,被选择单词会显示涵义。 上面是程 序的界面,非常的简单,但还是在使用sqlite3时费了我不少

经过一周的时间,终于完成了我的第一个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文件复制到环境下,数据库问题终于解决了。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读