错误C2440:“正在初始化”:无法从

时间:2018-08-15 09:42:30

标签: c++ sqlite unicode char stringstream

在C ++ 98中使用SQLite时,如何将stringstream转换为Unicode并将其传递给sqlite3_exec()?我经常遇到此错误:

error C2440: 'initializing' : cannot convert from 'std::basic_string<_Elem,_Traits,_Ax>' to 'std::basic_string<_Elem,_Traits,_Ax>'
1>        with"

代码:

int main(int argc, char* argv[]) {
    sqlite3 *db;
    char *zErrMsg = 0;
    int rc;
    char *sql;
    const char* data = "Callback function called";
    tstringstream tstrsSQL;
    tstrsSQL.imbue(std::locale("C"));

    std::string s = tstrsSQL.str(); // converting stringstream to char?
    const char* p = s.c_str();

    /* Open database */
    rc = sqlite3_open("db.db3", &db);

    if( rc ) {
        fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
        return(0);
    } else {
        fprintf(stderr, "Opened database successfully\n");
    }

    /* Create SQL statement */
    tstrsSQL << _T("SELECT") something ("FROM") << table;

    /* Execute SQL statement */
    rc = sqlite3_exec(db, p, callback, (void*)data, &zErrMsg); // p needs to be unicode

1 个答案:

答案 0 :(得分:1)

您使用的是tstringstream,如果定义了std::wstringstream,我想使用的是UNICODE,因此它的str()给出了std::basic_string<wchar_t>

但是您将结果存入std::string的{​​{1}}中。因此分配失败。

无论如何,您要获取结果并在std::basic_string<char>中使用它,而sqlite3_exec()将作为输入。

这就是为什么您不应该使用const char*,而应该使用tstringstream,并从所有字符串文字中删除std::stringstream的原因。

最小,完整,有效的代码:

_T