原型:char *strsep(char **stringp, const char *delim);

  功能:分解字符串为一组字符串, 此函数会改变字符串, 返回开始到 第一个出现 delim 的地方并在返回的字符串末尾自动加 ‘/0’,如果没有 delim,则返回NULL, 此函数 比strtok好处是接受空字符串并且是线程安全的。

 

      切割后源字符串变为第一个delim 到stringp 末尾。如果stringp 为NULL,则返回NULL,

 

  示例:

 

#include <stdio.h> 
  #include <string.h>
  int main(void)
  {
  char str[] = "root:x::0:root:/root:/bin/bash:";
  char *buf;
  char *token;
  buf = str;
  while((token = strsep(&buf, ":")) != NULL){
  printf("%s/n", token);
  }
  return 0;
  }
  再一个示例程序:
  #include <stdio.h>
  #include <string.h>
  void main()
  {
  char str[]="Number=100&maxMtu=200";
  char *name,*value,*next;
  int i;
  value=str; //使指针value 指向字符串str;
  for(i=0 ;i<2 ;i++)
  { // 第一次执行时
  name = strsep(&value,"="); // "="分割字符串,这时strsep函数返回值为 "Number",即"="号之前的字符串
  next =value; // 这时指针value指向"="号后面的字符串,即"100&maxMtu=200"
  value=strsep(&next,"&"); // 这时通过"&"分割字符串,返回值为100,next指 "maxMtu=200"
  printf(" name= %s/n",name); //打印出一轮分割后name的值
  printf("value= %s/n",value);
  value=next;
  }
  }
  执行结果为:
  name= Number
  value= 100
  name= maxMtu
  value= 200

注意 因为 strsep会完全分割字符串,所以如果不想改变源字符串,而只是想获取字符串中的特殊数据,应该用strdup函数复制一份,如:

char *src = "fjsd:43:fsdf:erer";

char *buf = strdup(src);
char *delime = NULL;
delime = strsep(&buf, ":");

这样,分割后输出src,并没有变化。否则(不先用strdup())会指向第一个:后面的字符串。

char *strrchr(const char *s, int c);
char *strchr(const char *s, int c);
strchr(const char *src, ':')

不改变源字符串,返回src中第一个 字符c出现的位置指针,包括 字符 c 到字符串末尾,所以如果不想在返回结果中包含 字符c 时可以 使返回指针向后移一位。

int main()
{
char src[] = "sdf:gjf:dgk";
char *buf = NULL;
char *token = NULL;
buf = src;
token = strchr(buf, ':');
printf("token : %s src : %s buf :%s /n", token,src,buf);

return 0;
}

输出 :token : :gjf:dgk  src : sdf:gjf:dgk buf :sdf:gjf:dgk

 

去掉 :则

int main()
{
char src[] = "sdf:gjf:dgk";
char *buf = NULL;
char *token = NULL;
buf = src;
token = strchr(buf, ':');
if(token) {
*token++ = '/0';
}
printf("token : %s src : %s buf :%s /n", token,src,buf); return 0;
}