Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/cplusplus/159.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C++ 如何访问成员变量sqlite回调_C++_Oop_Sqlite - Fatal编程技术网

C++ 如何访问成员变量sqlite回调

C++ 如何访问成员变量sqlite回调,c++,oop,sqlite,C++,Oop,Sqlite,我需要从sqlite回调函数访问类中的变量。它不能是静态的,因为我需要从其他函数访问此变量。这是我当前的代码 class fromdb { private: string paramdb; char* errmsg; string param; string title; string creator; char* bin; public: static int callback(void *data, int argc, char **argv,

我需要从sqlite回调函数访问类中的变量。它不能是静态的,因为我需要从其他函数访问此变量。这是我当前的代码

class fromdb {
private:
   string paramdb;
   char* errmsg;
   string param;
   string title;
   string creator;
   char* bin;
public:
     static int callback(void *data, int argc, char **argv, char **azColName){
        int lenght;
        lenght = sizeof(*argv[3]);
        title = *argv[1];
        creator = *argv[2];
        bin = new char[lenght];
        bin = argv[3];
        return 0;
}
void getdata() {
string tQuery = "SELECT * FROM test WHERE " + paramdb + "=\"" + param + "\" )";
  sqlite3_exec(db, tQuery.c_str(), fromdb::callback, (void*)data, &errmsg);
}
};
日志


您正在获取未定义的引用,因为您试图使用静态函数中的非静态成员

它不能是静态的,因为我需要从其他函数访问此变量

您仍然可以使用
静态
函数,但需要将成员作为传入,也可以使用
朋友
函数

在这里,我创建了一个更简单的代码版本来演示,使用了与您类似的
静态
函数,但传入了成员变量:

class artwork
{
private:
    std::string title;
    std::string creator;
public:
    static int populateFromDB(void* object, int, char** data, char**)
    {
        if (artwork* const art= static_cast<artwork*>(object))
        {
            art->title = data[1];
            art->creator = data[2];
        }
        return 0;
    }
};

artwork a;
char* error = nullptr;
if (sqlite3_exec(db, tQuery.c_str(), &artwork::populateFromDB, static_cast<void*>(&a), &error) != SQLITE_OK)
    sqlite_free(error)

您正在获取未定义的引用,因为您试图使用静态函数中的非静态成员

它不能是静态的,因为我需要从其他函数访问此变量

您仍然可以使用
静态
函数,但需要将成员作为传入,也可以使用
朋友
函数

在这里,我创建了一个更简单的代码版本来演示,使用了与您类似的
静态
函数,但传入了成员变量:

class artwork
{
private:
    std::string title;
    std::string creator;
public:
    static int populateFromDB(void* object, int, char** data, char**)
    {
        if (artwork* const art= static_cast<artwork*>(object))
        {
            art->title = data[1];
            art->creator = data[2];
        }
        return 0;
    }
};

artwork a;
char* error = nullptr;
if (sqlite3_exec(db, tQuery.c_str(), &artwork::populateFromDB, static_cast<void*>(&a), &error) != SQLITE_OK)
    sqlite_free(error)

将类的
this
指针通过第一个参数传递给回调参数see:
bin=newchar[lenght];bin=argv[3]为什么分配内存只是为了在下一行泄漏内存?更改为sqlite3_exec(db,tQuery.c_str(),this->callback,(void*)data,&errmsg);我有以下错误:/root/Dokumenty/musicdb/funcs.h | 94 |错误:非静态成员函数“int fromdb::callback(void*,int,char**,char**)”的使用无效|编辑问题以显示整个代码。将类的
this
指针通过第一个参数传递给callback参数请参见:
bin=new char[lenght];bin=argv[3]为什么分配内存只是为了在下一行泄漏内存?更改为sqlite3_exec(db,tQuery.c_str(),this->callback,(void*)data,&errmsg);我有以下错误:/root/Dokumenty/musicdb/funcs.h | 94 |错误:非静态成员函数“int fromdb::callback(void*,int,char**,char**)”的使用无效|编辑问题以显示整个代码。
class artwork
{
    friend int getArtwork(void*, int, char**, char**);
private:
    std::string title;
    std::string creator;
};    
int getArtwork(void* object, int, char** data, char**)
{
    if (artwork* const art = static_cast<artwork*>(object))
    {
        art->title = data[1];
        art->creator = data[2];
    }
    return 0;
}

artwork a;
char* error = nullptr;
if (sqlite3_exec(db, tQuery.c_str(), &getArtwork, static_cast<void*>(&a), &error) != SQLITE_OK)
    sqlite_free(error)