设为首页 加入收藏

TOP

c函数:strtok和strtok_r详解
2014-11-23 20:06:39 】 浏览:6091
Tags:函数 :strtok strtok_r 详解

  函数名: strtok


  功 能: 查找由在第二个串中指定的分界符分隔开的单词


  用 法: char *strtok(char *str1, char *str2);


  程序例:


  #include


  #include


  int main(void)


  {


  char input[16] = "abc,d";


  char *p;


  /* strtok places a NULL terminator


  in front of the token, if found */


  p = strtok(input, ",");


  if (p) printf("%s\n", p);


  /* A second call to strtok using a NULL


  as the first parameter returns a pointer


  to the character following the token */


  p = strtok(NULL, ",");


  if (p) printf("%s\n", p);


  return 0;


  }


  带有_r的函数主要来自于UNIX下面。所有的带有_r和不带_r的函数的区别的是:带_r的函数是线程安全的,r的意思是reentrant,可重入的。


  上述程序运行的结果是


  abc


  d


  1. strtok介绍


  众所周知,strtok可以根据用户所提供的分割符(同时分隔符也可以为复数比如“,。”)


  将一段字符串分割直到遇到"\0".


  比如,分隔符=“,” 字符串=“Fred,John,Ann”


  通过strtok 就可以把3个字符串 “Fred” “John” “Ann”提取出来。


  上面的C代码为


  QUOTE:


  int in=0;


  char buffer[]="Fred,John,Ann"


  char *p[3];


  char *buff = buffer;


  while((p[in]=strtok(buf,","))!=NULL) {


  i++;


  buf=NULL; }


  如上代码,第一次执行strtok需要以目标字符串的地址为第一参数(buf=buffer),之后strtok需要以NULL为第一参数 (buf=NULL)。指针列p[],则储存了分割后的结果,p[0]="John",p[1]="John",p[2]="Ann",而buf就变成 Fred\0John\0Ann\0。


  2. strtok的弱点


  让我们更改一下我们的计划:我们有一段字符串 "Fred male 25,John male 62,Anna female 16" 我们希望把这个字符串整理输入到一个struct,


  QUOTE:


  struct person {


  char [25] name ;


  char [6] sex;


  char [4] age;


  }


  要做到这个,其中一个方法就是先提取一段被“,”分割的字符串,然后再将其以“ ”(空格)分割。


  比如: 截取 "Fred male 25" 然后分割成 "Fred" "male" "25"


  以下我写了个小程序去表现这个过程:


  QUOTE:


  #include


  #include


  #define INFO_MAX_SZ 255


  int main()


  {


  int in=0;


  char buffer[INFO_MAX_SZ]="Fred male 25,John male 62,Anna female 16";


  char *p[20];


  char *buf=buffer;


  while((p[in]=strtok(buf,","))!=NULL) {


  buf=p[in];


  while((p[in]=strtok(buf," "))!=NULL) {


  in++;


  buf=NULL;


  }


  p[in++]="***"; //表现分割


  buf=NULL; }


  printf("Here we have %d strings\n",i);


  for (int j=0; j


  printf(">%s<\n",p[j]);


  return 0;


  }


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇计算机二级考试C语言辅导:fabs函.. 下一篇嵌套的菱形算法

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目