zoukankan      html  css  js  c++  java
  • strtok和strtok_r

    转自 http://blog.csdn.net/libuding/article/details/5870089

    原型:char *strtok(char *s, char *delim);

    功能:分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。

    说明:首次调用时,s指向要分解的字符串,之后再次调用要把s设成NULL。
            strtok在s中查找包含在delim中的字符并用NULL('/0')来替换,直到找遍整个字符串。

    返回值:从s开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。
               所有delim中包含的字符都会被滤掉,并将被滤掉的地方设为一处分割的节点。

    举例:

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

        int main(void) 

            char input[16] = "abc,d"; 
            char *p; 

       /* strtok places a NULL terminator 
            in front of the token, if found */ 
            p = strtok(input, ","); 
            if (p)      printf("%s ", p); 

       /* A second call to strtok using a NULL 
            as the first parameter returns a pointer 
            to the character following the token  */ 
            p = strtok(NULL, ","); 
            if (p)      printf("%s ", p); 

            return 0; 
       }

          函数第一次调用需设置两个参数。第一次分割的结果,返回串中第一个 ',' 之前的字符串,也就是上面的程序第一次输出abc。

          第二次调用该函数strtok(NULL,"."),第一个参数设置为NULL。结果返回分割依据后面的字串,即第二次输出d。

    带有_r的函数主要来自于UNIX下面。所有的带有_r和不带_r的函数的区别的是:带_r的函数是线程安全的,r的意思是reentrant,可重入的。

    strtok介绍
    众所周知,strtok可以根据用户所提供的分割符(同时分隔符也可以为复数比如“,。”)
    将一段字符串分割直到遇到"/0".

    比如,分隔符=“,” 字符串=“Fred,John,Ann”
    通过strtok 就可以把3个字符串 “Fred”     “John”      “Ann”提取出来。
    上面的C代码为

    QUOTE:
    int in=0;
    char buffer[]="Fred,John,Ann"
    char *p[3];
    char *buf = buffer;
    while((p[in]=strtok(buf,","))!=NULL) {
                     in++;
                     buf=NULL; }

    如上代码,第一次执行strtok需要以目标字符串的地址为第一参数(buf=buffer),之后strtok需要以NULL为第一参数 (buf=NULL)。指针列p[],则储存了分割后的结果,p[0]="John",p[1]="John",p[2]="Ann",而buf就变成    Fred/0John/0Ann/0。

     strtok是一个线程不安全的函数,因为它使用了静态分配的空间来存储被分割的字符串位置 。

  • 相关阅读:
    SpringCloud Gateway使用实例
    Nacos服务注册与发现
    HashMap源码分析——put方法
    Volatile关键字——内存可见性
    Java的JIT编译器
    why spring?
    mysql 锁
    sql server 表变量和临时表
    mysql 存储过程
    mysql 截取字符串
  • 原文地址:https://www.cnblogs.com/ph829/p/4054667.html
Copyright © 2011-2022 走看看