必威体育Betway必威体育官网
当前位置:首页 > IT技术

strtok的实现与原理

时间:2019-10-17 14:14:38来源:IT技术作者:seo实验室小编阅读:81次「手机版」
 

strtok

  该函数包含在"string.h"头文件中

函数原型:

  1. char* strtok (char* str,constchar* delimiters );

函数功能:

  切割字符串,将str切分成一个个子串

函数参数:

  str:在第一次被调用的时间str是传入需要被切割字符串的首地址;在后面调用的时间传入NULL。

  delimiters:表示切割字符串(字符串中每个字符都会 当作分割符)。

函数返回值:

  当s中的字符查找到末尾时,返回NULL;

  如果查不到delimiter所标示的字符,则返回当前strtok的字符串的指针


使用strtok()函数:

  1. 复制代码

    #include<stdio.h>
    #include<string.h>
    int main(void)
    {
        char buf[]="hello@boy@this@is@heima";
        char*temp = strtok(buf,"@");
        while(temp)
        {
            printf("%s ",temp);
            temp = strtok(NULL,"@");
        }
        return0;
    }

    复制代码

预计输出结果:

  "hello boy this is heima "

实际运行结果:

得到的结论:

  strtok在切割字符串的时间,实际上就是将分割符的字符delimiter替换为'\0'并且返回首地址。


自己实现strtok()函数原理:

函数代码

  1. 复制代码

    复制代码

    #include<stdio.h>
    #include<string.h>
    //根据函数原型实现strtok()函数
    char* myStrtok_origin(char* str_arr,constchar* delimiters,char**temp_str)
    {
        //定义一个指针来指向待分解串
        char*b_temp;
        /*
        * 1、判断参数str_arr是否为空,如果是NULL就以传递进来的temp_str作为起始位置;
        * 若不是NULL,则以str为起始位置开始切分。
        */
        if(str_arr == NULL)
        {
            str_arr =*temp_str;
        }
        //2、跳过待分解字符串
        //扫描delimiters字符开始的所有分解符
        str_arr += strspn(str_arr, delimiters);
        //3、判断当前待分解的位置是否为'\0',若是则返回NULL,否则继续
        if(*str_arr =='\0')
        {
            return NULL;
        }
        /*
        * 4、保存当前的待分解串的指针b_temp,调用strpbrk()在b_temp中找分解符,
        * 如果找不到,则将temp_str赋值为待分解字符串末尾部'\0'的位置,
        * b_temp没有发生变化;若找到则将分解符所在位置赋值为'\0',
        * b_temp相当于被截断了,temp_str指向分解符的下一位置。
        */
        b_temp = str_arr;
        str_arr = strpbrk(str_arr, delimiters);
        if(str_arr == NULL)
        {
            *temp_str = strchr(b_temp,'\0');
        }
        else
        {
            *str_arr ='\0';
            *temp_str = str_arr +1;
        }
        //5、函数最后部分无论找没找到分解符,都将b_temp返回。
        return b_temp;
    }
    //使用myStrtok来简化myStrtok_origin函数
    char* myStrtok(char* str_arr,constchar* delimiters)
    {
        staticchar*last;
        return myStrtok_origin(str_arr, delimiters,&last);
    }
    int main(void)
    {
        char buf[]="hello@boy@this@is@heima";
        //1、使用myStrtok_origin()函数
        char*temp_str = NULL;
        char*str = myStrtok_origin(buf,"@",&temp_str);
        while(str)
        {
            printf("%s ",str);
            str = myStrtok_origin(NULL,"@",&temp_str);
        }
        //2、使用myStrtok()函数
        char*str1 = myStrtok(buf,"@");
        while(str1)
        {
            printf("%s ",str1);
            str1 = myStrtok(NULL,"@");
        }
        return0;
    }        

    复制代码

    复制代码

  完美实现!!!


拓展知识点:可重入与不可重入函数

可重入函数:

  指一个可以被多个任务调用的函数(过程),任务在调用时不必担心数据是否会出错。

不可重入函数:

  如果函数接口的代码实现中在块内定义和使用了static存储类型的变量,这种函数将是不可重入函数。它在实时系统中是不安全函数

相关阅读

strtok 和strtok_r 函数使用

strtok这个函数我们再熟悉不过了,因为我们要经常要和字符打交道,不可避免的要分割字符串连接字符串。那么我今天看一下分割字符串。

strtok()函数详解!

strtok()函数详解!1.定义分解字符串为一组字符串。s为要分解的字符,delim为分隔符字符(如果传入字符串,则传入的字符串中每个字符均为

使用C分隔函数strtok的两个细节

Tokenizer函数strtok是常用的函数,可以用来对某个字符串分隔成几段,若只是分隔单个串没什么问题,但不当使用会产生意料外的结果。str

C语言切割多层字符串(strtok_r strtok使用方法)

转载地址:https://www.jb51.net/article/43744.htm 1.strtok介绍 众所周知,strtok可以根据用户所提供的分割符(同时分隔符也可以为

分享到:

栏目导航

推荐阅读

热门阅读