0

我目前正在使用 sqlite3 在 Objective-C 上进行开发。以下代码似乎是错误的内存访问。

-(sqlite3_stmt *)PrepareStmt:(NSString *)query
{
    //...
    const char *query_stmt = [query UTF8String];
    sqlite3_stmt *stmt = nil;
    int retval = 0;

    if ((retval = sqlite3_prepare_v2(db, query_stmt, -1, &stmt, nil)) == SQLITE_OK)
    {
        return stmt;
    }
    else
    {
        //Error handling...
    }
}

- (void)SomeFunc
{
    NSString *query = @""; //Assume valid SQL statement
    sqlite3_stmt *stmt = [self PrepareStmt:query];

    //Use stmt, like step, etc.

    sqlite3_finalize(stmt);
}

PrepareStmt 中的 sqlite3_stmt 设置为 nil,它将是 sqlite3_prepare_v2() 的输出参数。应该在该函数中分配内存。因此,应该通过调用 sqlite3_finalize() 来释放它。

我的问题是,如果我们从 PrepareStmt() 返回 sqlite3_stmt,它应该仍然有效,对吧?PrepareStmt() 中的本地指针已经从堆栈中弹出,但 sqlite3_prepare_v2() 分配的内存应该仍然有效。

这种想法有效吗?或者我是否需要传递指向 PrepareStmt() 的指针地址?

谢谢!

4

1 回答 1

2

是的,在这种情况下它是有效的。但请注意 sqlite3_finalize() 不仅仅是释放内存(即 dealloc)。它还向数据库发送一条消息,告诉它删除它的预编译 SQL 语句等......

于 2012-04-25T02:12:05.987 回答