2

可能重复:
将 strtok 与 std::string 一起使用

#include<iostream>
#include <string>
#include <string.h>

using namespace std;

int main()
{
    string s("hello hi here whola");
    string background;
    char *strval;

    char* tok = strtok_r(s.c_str()," ",&strval);
    while(tok !=NULL)
    {
    cout << tok <<"\n";
    if (tok == "&")
        background = tok;
    else
    {
        statements1;
        statement2.. ;
    }
    tok = strtok_r(NULL, " ",&strval);
    }

    return 0;
}

输出:

new.cpp: In function ‘int main()’:
new.cpp:13:47: error: invalid conversion from ‘const char*’ to ‘char*’ [-fpermissive]
/usr/include/string.h:359:14: error:   initializing argument 1 of ‘char* strtok_r(char*, const char*, char**)’ [-fpermissive]
4

3 回答 3

10

返回一个指向 const char的s.c_str()指针,以防止您修改备份内存。您需要制作此常量字符串的可写副本,例如 with strdup()function asstrtok()真正修改您正在扫描令牌的字符串。

于 2012-10-13T14:46:50.470 回答
1

strtok修改它的论点。这是不允许的,string.c_str()因为它是一个const char*

此外,即使它有效,您if( tok == "&" )也不会工作,因为 tok 是一个字符 *,而不是字符串,因此您将进行指针而不是内容比较。

你需要使用strcmp()

既然您使用的是字符串,为什么不尝试使用其他 C++ 结构呢?

stringstream ss(s);
string tmp; 
while (ss >> buf) {
    if( buf == "&" ) background = buf; // one wonders why
    cout << buf << '\n';
}
于 2012-10-13T14:47:46.460 回答
0

您的代码将 C++ strings 和couts 与 Cstrtok_r函数混合。这不是一个好的组合。

您的错误的直接原因是c_str()返回一段const char *时间strtok()要求一个非常量char *。它想要修改您作为参数传递的字符串,并且不允许您修改c_str()返回的字符串。

如果你想做这种 C 风格,那么切换schar[].

char s[] = "hello hi here whola";
int background = 0;
char *strval;

char* tok = strtok_r(s, " ", &strval);
while (tok != NULL)
{
    printf("%s\n", tok);

    if (strcmp(tok, "&") == 0)
        background = 1;
    else
    {
        statement1;
        statement2;
        ...
    }

    tok = strtok_r(NULL, " ", &strval);
}
于 2012-10-13T14:48:27.860 回答