字符串函數之Strtok()函數

Strtok()函數詳解:

  該函數包含在"string.h"頭文件中
函數原型:安全

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

函數功能:
  切割字符串,將str切分紅一個個子串
函數參數:
  str:在第一次被調用的時間str是傳入須要被切割字符串的首地址;在後面調用的時間傳入NULL。
  delimiters:表示切割字符串(字符串中每一個字符都會 看成分割符)。
函數返回值:
  當s中的字符查找到末尾時,返回NULL;
  若是查不到delimiter所標示的字符,則返回當前strtok的字符串的指針。函數


使用strtok()函數:this

  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;
    }

     

預計輸出結果:spa

  "hello boy this is heima "指針

實際運行結果:
code

獲得的結論:
  strtok在切割字符串的時間,實際上就是將分割符的字符delimiter替換爲'\0'而且返回首地址。blog


本身實現strtok()函數原理:

函數代碼:

  1. #include<stdio.h>
    #include<string.h>
    //根據函數原型實現strtok()函數
    char* myStrtok_origin(char* str_arr,constchar* delimiters,char**temp_str)
    {
        //定義一個指針來指向待分解串
        char*b_temp;
        /*
        * 一、判斷參數str_arr是否爲空,若是是NULL就以傳遞進來的temp_str做爲起始位置;
        * 若不是NULL,則以str爲起始位置開始切分。
        */
        if(str_arr == NULL)
        {
            str_arr =*temp_str;
        }
        //二、跳過待分解字符串
        //掃描delimiters字符開始的全部分解符
        str_arr += strspn(str_arr, delimiters);
        //三、判斷當前待分解的位置是否爲'\0',如果則返回NULL,不然繼續
        if(*str_arr =='\0')
        {
            return NULL;
        }
        /*
        * 四、保存當前的待分解串的指針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;
        }
        //五、函數最後部分不管找沒找到分解符,都將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";
        //一、使用myStrtok_origin()函數
        char*temp_str = NULL;
        char*str = myStrtok_origin(buf,"@",&temp_str);
        while(str)
        {
            printf("%s ",str);
            str = myStrtok_origin(NULL,"@",&temp_str);
        }
        //二、使用myStrtok()函數
        char*str1 = myStrtok(buf,"@");
        while(str1)
        {
            printf("%s ",str1);
            str1 = myStrtok(NULL,"@");
        }
        return0;
    }        

     

     

  完美實現!!!接口


拓展知識點:可重入與不可重入函數

可重入函數:
  指一個能夠被多個任務調用的函數(過程),任務在調用時沒必要擔憂數據是否會出錯。
不可重入函數:
  若是函數接口的代碼實現中在塊內定義和使用了static存儲類型的變量,這種函數將是不可重入函數。它在實時系統中是不安全函數字符串

相關文章
相關標籤/搜索