◆ 使用strtok函数分割。

原型:char *strtok(char *s, char *delim);
strtok在s中查找包含在delim中的字符并用NULL('\0')来替换,直到找遍整个字符串。 
功能:分解字符串为一组字符串。s为要分解的字符串,delim为分隔符字符串。
说明:首次调用时,s指向要分解的字符串,之后再次调用要把s设成NULL。
           strtok在s中查找包含在delim中的字符并用NULL('\0')来替换,直到找遍整个字符串。
返回值:从s开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。
           所有delim中包含的字符都会被滤掉,并将被滤掉的地方设为一处分割的节点。

使用例:

#include <stdio.h>
#include <string.h> int main(int argc,char **argv)
#include <stdio.h>
#include <string.h> int main(int argc,char **argv)
{ char * buf1="aaa, ,a, ,,,bbb-c,,,ee|abc"; /* Establish string and get the first token: */
char* token = strtok( buf1, ",-|");
while( token != NULL )
{
/* While there are tokens in "string" */
printf( "%s ", token );
/* Get next token: */
token = strtok( NULL, ",-|");
}
return ; }

OUT 值: 
aaa
a
bbb
c
ee
abc

◆ 使用strstr函数分割。

原型:extern char *strstr(char *haystack, char *needle);
        
 用法:#include <string.h>
  
 功能:从字符串haystack中寻找needle第一次出现的位置(不比较结束符NULL)。
  
 说明:返回指向第一次出现needle位置的指针,如果没找到则返回NULL。

使用例:

#include <stdio.h>
#include <string.h> int main(int argc,char **argv)
{
char *haystack="aaa||a||bbb||c||ee||";
char *needle="||";
char* buf = strstr( haystack, needle);
while( buf != NULL )
{
buf[]='\0';
printf( "%s\n ", haystack);
haystack = buf + strlen(needle);
/* Get next token: */
buf = strstr( haystack, needle);
}
return ;
}

OUT 值: 
aaa
 a
 bbb
 c
 ee

 strtok比较适合多个字符作分隔符的场合,而strstr适合用字符串作分隔符的场合。

最新文章

  1. 用open_gapps安装google play
  2. Linux查看设置系统时区
  3. /proc 【虚拟文件系统】
  4. SaltStack 入门(赵班长)
  5. android 录音的断点续传
  6. checkbox组件
  7. StarUML启动时候出现&quot;System Error. Code:1722. RPC服务器不可用.&quot;错误的解决办法
  8. Junit 源码剖析(一)
  9. 关于DB2死锁处理
  10. tp框架表单验证 及ajax
  11. VS2013 工程属性配置
  12. 【转】UNREFERENCED_PARAMETER的作用
  13. mvc 过滤器篇
  14. Linux 局域网同步时间
  15. Mockito 的使用
  16. BZOJ 2330 糖果 差分约束求最小值
  17. pytorch--cnn的理解
  18. spring注解扫描组件注册
  19. ubuntu 18.4 鼠标右键菜单 添加文件
  20. JSON语法及JSON定义规范化

热门文章

  1. 如何将含有byte数据项的结构存入MongoDb
  2. [Xcode 实际操作]八、网络与多线程-(10)使用异步Get方式查询GitHub数据
  3. ACM2015沈阳:B-Bazinga
  4. python使用rabbitmq实现简单的消息转发
  5. Redis的分布式锁
  6. Tinghua Data Mining 6
  7. siege官方文档(译)(二)
  8. MySQL之select简单使用
  9. c#学习系列之字段(静态,常量,只读)
  10. D. Anton and Chess 模拟题 + 读题