??该函数包含在"string.h"头文件中
函数原型:
char* strtok (char* str,constchar* delimiters );函数功能:
??切割字符串,将str切分成一个个子串
函数参数:
??str:在第一次被调用的时间str是传入需要被切割字符串的首地址;在后面调用的时间传入NULL。
??delimiters:表示切割字符串(字符串中每个字符都会 当作分割符)。
函数返回值:
??当s中的字符查找到末尾时,返回NULL;
??如果查不到delimiter所标示的字符,则返回当前strtok的字符串的指针。
使用strtok()函数:
#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‘并且返回首地址。
#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存储类型的变量,这种函数将是不可重入函数。它在实时系统中是不安全函数
原文:http://www.cnblogs.com/Bob-tong/p/6610806.html