【C语言】浅谈strtok()与NULL

一、strtok(  )函数

strtok(  )函数包含于头文件string.h

语法:char *strtok( char *str1, const char *str2 ); 

功能:函数返回字符串str1中紧接“标记”的部分的指针, 字符串str2是作为标记的分隔符。如果分隔标记没有找到,函数返回NULL。为了将字符串转换成标记,第一次调用str1 指向作为标记的分隔符。之后所以的调用str1 都应为NULL


二、代码

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



三、运行结果

【C语言】浅谈strtok()与NULL_第1张图片



四、浅谈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进行分隔的效果。


你可能感兴趣的:(C&C++)