一、strpbrk:
调用格式:result = strpbrk(source-string, searching-string)
用途:在源字符串(source-string)中找出最先含有搜索字符串(searching-string)中的任一字符的位置并返回,若找不到则返回空指针。
注意:返回值是指向源字符串的指针,所以在使用返回结果的时候,请确保源字符串的有效性。
举MSDN中的例子:
数据:
char string[100] = "The 3 men and 2 boys ate 5 pigs\n";
char *result;
调用:
result = strpbrk( string, "0123456789" );//在string中找出最先出现0~9中某一个字符的位置
printf( "1: %s\n", result++ );
result = strpbrk( result, "0123456789" );
printf( "2: %s\n", result++ );
result = strpbrk( result, "0123456789" );
printf( "3: %s\n", result );
输出的结果是:
1. 3 men and 2 boys ate 5 pigs//最先发现3
2: 2 boys ate 5 pigs//最先发现2,注意这时开始源串是上一次的结果的下一位置,即跳过了数字'3',下同
3: 5 pigs//最先发现5
二、strtok:
用法:token = strtok(source-str,seperator-str)
用途:在source-str中找出以seperator-str中的字符为分隔的字符串,即是源串中除去了含有分隔串中的所有字符后余下的一段段的字符串,每调用一次找到一串,找不到则返回空串。
注意:返回值是指向源串的指针,所以同样要保证源串的有效性,此外,每次调用返回找到的子串的时候都会把源串中该子串的尾部字符(原来是搜索串中的某一字符)修改成'\0'字符。还有一个要注意的是,这个函数使用全局的静态缓冲区(函数自己的静态buffer),所以在某一个线程里不要同时调用这个函数来处理两个字符串,否则极易出现不正常的结果,正确的处理方法是先找出一个字符串中的所有子串,然后才转到处理另一个字符串。多线程之间则不会出现这种干扰。
同样举MSDN中的例子:
数据准备:
char string[] = "A string\tof ,,tokens\nand some more tokens";
char seps[] = " ,\t\n";
char *token;
调用示例:
token = strtok( string, seps );
while( token != NULL )
{
/* While there are tokens in "string" */
printf( " %s\n", token );
/* Get next token: */
token = strtok( NULL, seps );
/*注意到上面这个NULL,它表明的是从上次调用结果中strtok自有的缓冲区中继续取出余下的子串*/
}
显示结果:
A //此时string[1]='\0',原先为空格
string
of
tokens
and
some
more
tokens
Feedback
# re: C语言中strtok与strpbrk的区别(转) 回复 更多评论
2008-06-27 09:33 by
true 可否谈谈为什么 多线程之间则不会出现这种干扰
# re: C语言中strtok与strpbrk的区别(转) 回复 更多评论
2008-06-27 10:10 by
不怎么厉害 http://www.zzGps.cn 在线技术视频
http://bbs.ZzGps.Cn 技术视频下载
技术视频提供,分类清晰,技术覆盖面广,几千视频助您轻松学习
# re: C语言中strtok与strpbrk的区别(转) 回复 更多评论
2008-06-27 10:58 by
Jeff Chen @true
我觉得strtok使用的缓冲区应该是TLS的。每个线程的TLS都是独立的,相互隔离的。这样的话,在多个线程中调用strtok函数才不会相互影响,出现类似在同一个线程中同时调用strtok两次或以上时,出现的不正常情况。