在C ++中使用SQLite:对象函数作为回调

时间:2014-01-20 20:56:57

标签: c++ c sqlite oop callback

所以,我正在开展一个侧面项目,以保持我的c ++技能新鲜(自从我用c ++完成工作已经很多年了)。我正在开发一些我将使用SQLite的东西。我有一个SQLite代码的包装器。我注意到的一件事是SQLite在其sqlite3_exec(...)函数中使用了c风格的回调函数。

我希望将回调函数作为对象方法,因为我希望它能够修改对象变量,但我不确定如何完全执行此操作。我已经检查了stackoverflow上的其他类似问题,但没有任何帮助。

以下是我如何声明我的包装类:

class DBAdapter
{
private:
    sqlite3* db;
    int getUserRecords(std::string);
    std::vector<USER_RECORD> records;

    int callbackSel(void*, int , char**, char**);

public:
    DBAdapter();
    ~DBAdapter();

    int open(std::string);
    void close();

    int insertRecord();
    int deleteRecord();
    int getNumUserRecords();
};

以下是我在getNumUserRecords中尝试使用回调(callbackSel)的方法:

int DBAdapter::getUserRecords(std::string name)
{
    std::string sql = "SELECT" + name + " from USERS";
    char* ErrMsg;
    char* data;

    int retval = sqlite3_exec(db,sql.c_str(),this->callbackSel,data,&ErrMsg);
    return retval;
}

我收到的错误消息是:

 error: ‘int (* DBAdapter::callbackSel)(void*, int, char**, char**)’ is not a static member of ‘class DBAdapter’

我的问题是,如果我将其设为静态函数,我将无法访问我的矢量,记录,对吧?有没有办法解决这个问题?

1 个答案:

答案 0 :(得分:1)

  

有什么方法吗?

我不知道具体是 API,但通常c风格的回调支持从void*指针传递用户数据(我猜你提到的那个签名的第一个参数) )。通常做的是:

  1. 声明一个静态类函数以指定为回调函数指针
  2. 实现该函数以将传递的用户数据指针强制转换为指向类实例的指针并调用成员函数
  3. 在提供所需实现的类中定义成员函数
  4. 当您要使用C API注册静态成员函数指针时,将指针传递给您的处理类实例
  5. 我希望这指出了正确的方向。