C:正确使用strtok_r

时间:2013-04-12 00:41:33

标签: c char strtok

如何使用strtok_r而不是strtok来执行此操作?

char *pchE = strtok(NULL, " ");

现在我正在尝试正确使用strtok_r ...但有时我会遇到strtol的问题。 我有一个我执行10次(同时)的线程。

char *savedEndd1;
char *nomeClass = strtok_r(lineClasses, " ", &savedEndd1);
char *readLessonS = strtok_r (NULL, " ", &savedEndd1);
char *readNTurma = strtok_r(NULL, " ",  &savedEndd1);

if (readNTurma==NULL)
printf("CLASS STRTOL begin %s %s\n",nomeClass, readLessonS );
int numberNTurma = strtol(readNTurma, NULL, 10);

我几次抓住readNTurma == NULL ......为什么会这样?不明白为什么会出现NULL

4 个答案:

答案 0 :(得分:38)

strtok_r的documentation非常清楚。

  

strtok_r()函数是一个可重入的版本strtok()。 saveptr参数是一个指向char *变量的指针,该变量由strtok_r()在内部使用,以便在解析相同字符串的连续调用之间维护上下文。

     

在第一次调用strtok_r()时,str应指向要解析的字符串,并忽略saveptr的值。在后续调用中,str应为NULL,并且自上次调用以来saveptr应保持不变。

所以你有像

这样的代码
char str[] = "Hello world";
char *saveptr;
char *foo, *bar;

foo = strtok_r(str, " ", &saveptr);
bar = strtok_r(NULL, " ", &saveptr);

答案 1 :(得分:13)

经过测试的例子:

#include <stdio.h>
#include <string.h>

int main(void)
{
    char str[] = "1,22,333,4444,55555";
    char *rest = NULL;
    char *token;

    for (token = strtok_r(str, ",", &rest);
         token != NULL;
         token = strtok_r(NULL, ",", &rest)) {   
        printf("token:%s\n", token);
    }

    return 0;
}

结果。

token:1
token:22
token:333
token:4444
token:55555

测试:http://codepad.org/6xRdIecI

从重点是我的linux documentation开始:

char *strtok_r(char *str, const char *delim, char **saveptr);
  

strtok_r()函数是一个可重入的版本strtok()。 saveptr参数是指向char *变量的指针,该变量由strtok_r()在内部使用,以便在解析相同字符串的连续调用之间维护上下文

     

在第一次调用strtok_r()时,str应指向要解析的字符串,将忽略saveptr的值。在后续调用中,str应为NULL,并且自上次调用后saveptr应保持不变

     

可以使用指定不同saveptr参数的strtok_r()调用序列同时解析不同的字符串。

答案 2 :(得分:1)

char str[]="string for sample";
char *reserve;
char *pchE = strtok_r(str, " ", &reserve);//when next call str -> NULL

答案 3 :(得分:1)

我发布了一个经过测试的示例,以了解strtok_r()的正确用法,而不是在嵌套中使用strtok()。

首先让我们接受一个字符串“ y.o.u,a.r.e,h.e.r.e” 并使用定界符“,”和“。”分隔

  

使用strtok()

#include<stdio.h>
#include<string.h>
int main(void) {

        char str[]="y.o.u,a.r.e,h.e.r.e";
        const char *p=",", *q=".";
        char *a,*b;

        for( a=strtok(str,p) ; a!=NULL ; a=strtok(NULL,p) ) {
                printf("%s\n",a);
                for( b=strtok(a,q) ; b!=NULL ; b=strtok(NULL,q) )
                        printf("%s\n",b);
        }

        return 0;
}

输出:

  

y.o.u
  y
  o
  你

现在让我们使用strtok_r()作为同一示例

  

使用strtok_r()

#include<stdio.h>
#include<string.h>
int main(void) {

        char str[]="y.o.u,a.r.e,h.e.r.e";
        const char *p=",",*q=".";
        char *a,*b,*c,*d;

        for( a=strtok_r(str,p,&c) ; a!=NULL ; a=strtok_r(NULL,p,&c) ) {
                printf("%s\n",a);

                for( b=strtok_r(a,q,&d) ; b!=NULL ; b=strtok_r(NULL,q,&d) )
                        printf("%s\n",b);
        }

        return 0;
}

输出:

  

y.o.u
  y
  o
  u
  a.r.e
  一个
  r
  e
  h.e.r.e
  h
  e
  r
  e

因此,strtok_r()具有可重入属性,而strtok()不能那样工作。