一、strtok( )函数
strtok( )函数包含于头文件string.h
语法:char *strtok( char *str1, const char *str2 );
功能:函数返回字符串str1中紧接“标记”的部分的指针,
字符串str2是作为标记的分隔符。如果分隔标记没有找到,函数返回NULL。为了将字符串转换成标记,第一次调用str1
指向作为标记的分隔符。之后所以的调用str1 都应为NULL
二、代码
#include<stdio.h> #include<string.h> int main() { char p[]="My name is XiaoMing."; char tmp[20]; char *sep=" "; char *token=NULL; strcpy(tmp,p); for(token=strtok(tmp,sep);token != NULL; token=strtok(NULL,sep)) { printf("%s\n",token); } return 0; }
三、运行结果
四、浅谈strtok( )函数与NULL
函数strtok( char *str1, const
char *str2 ) 涉及到两个指针。
第一个指针pointer_a用来指向函数返回的字符串,这个字符串是被原字符串OriginalString被seps中的字符截断后的第一个字符串。
第二个指针pointer_b用来指向OriginalString中,匹配截断字串seps的位置。
如果在第二次函数调用的时候,第一个参数不是设置为NULL而是设为原来的字符串"My
name is XiaoMing.",那么讲永远返回"My"并且也将陷入死循环。
为何会出现这种结果呢?
原因是:
第一次调用这个函数是在while循环体之外(第19行),此时,字符串"My name is XiaoMing." 中匹配token(即参数seps代表的各种字符,如本例中," ,/t/n"表示空格,逗号,制表符,换行符这四种字符)中所指定的字符的位置在My和name之间。于是,函数的返回值pointer_a为一个指向”My”的指针。此时,pointer_b指向My和name之间的位置,代表pointer_b之前的位置已经进行过查找匹配了。
这样,在循环体之内进行第二次函数调用的时候,只要把strtok()的第一个参数设置为NULL,就可以直接从pointer_b位置开始进行查找匹配了。
所以,NULL的作用只是为了使得每次调用时,都不是从"My name is XiaoMing."的头开始,而是从上次调用时查找所停止的位置开始,如此循环下去,直到无法再找到匹配token的时候位置,这样就实现了把"My name is XiaoMing."按照token进行分隔的效果。