strsep

原型: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;
}

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值