2

所以,我已经阅读了我在互联网上找到的所有帖子,但我似乎仍然无法完成这项工作。

我正在尝试将大量数据插入 sqlite 数据库。这是20000行数据,所以我必须在后台线程中进行。

我有一个 NSObject .h 和 .m 文件来处理数据库操作。我从我的主视图中调用它们。

这是我的代码:

SQLiteDBHandler.m :

 database = [FMDatabase databaseWithPath:[self getDBPath]];
    [database open];
    dispatch_queue_t q = dispatch_queue_create("FMDBQueue", NULL);
    dispatch_async(q, ^{
        for(Customer *c in arrayOfObjects) {
            [database executeUpdate:@"INSERT INTO SNP(rdis, Position, FirstName, LastName) VALUES (?,?,?,?)", c.ID, c.Position, c.FirstName, c.LastName];
        }
        [database close];
    });

为了在主视图中调用该方法,我这样称呼它:

SQLiteDBHandler *dbHandler = [[SQLiteDBHandler alloc]init];

[dbHandler insertDataIntoTable:mutableArray];

我试过用 FMDatabaseQueue 更改 FMDatabase,但没有成功。因此,任何帮助将不胜感激,因为我对此非常绝望。

谢谢。干杯!

4

2 回答 2

1

如果您调用InsertDataIntoTable两次或尝试访问数据库的任何其他方法,您可能会遇到数据库连接在您有时间执行查询之前关闭的情况。考虑这种情况:

  1. 线程 1 打开数据库连接
  2. 线程 2 打开数据库连接
  3. 线程 1 向队列中添加一个块
  4. 线程 2 将一个块添加到队列中
  5. 线程 1 完成运行并关闭数据库连接
  6. 线程 2 尝试运行他的块,但数据库连接已经关闭。

尝试[database open]在块内调用。

于 2013-03-19T11:38:51.930 回答
0

EXC_BAD_ACCESS 意味着你有一个僵尸,启用僵尸对象并使用工具工具,它会告诉你僵尸对象在哪里。这里的这个链接是关于如何检测它们的一个很好的教程

http://www.raywenderlich.com/2696/how-to-debug-memory-leaks-with-xcode-and-instruments-tutorial

希望有帮助

编辑:

在 xCode 中,屏幕顶部的工具栏 Product->Edit Scheme->Diagnostics-> 单击 Enable Zombie Objects

然后在屏幕顶部的工具栏上选择产品,然后进入配置文件,仪器应该会出现,你应该看到僵尸选项,选择它。

编辑2:

忘了说,僵尸模板只有在模拟器上分析时才会出现,如果你在实际设备上尝试分析,它不会出现

编辑3:图片

在此处输入图像描述

然后你应该看到这个

在此处输入图像描述

然后,当您运行应用程序时,导航到发生错误的屏幕,应用程序应该停止,并且应该出现

在此处输入图像描述

单击错误消息旁边的箭头,它应该显示在堆栈跟踪中发生错误的位置

于 2013-03-19T09:27:53.183 回答