鱼C论坛

 找回密码
 立即注册
查看: 386|回复: 1

strtok函数

[复制链接]
发表于 2023-12-28 21:21:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>

  4. int main()
  5. {
  6.     char str[]="123#ban#123456"; //strtok
  7.     char *p[10]={NULL};
  8.     char *p1=strtok(str,"#");  //str中将#进行切割返回前面的字符串
  9.     // printf("%s\n",p1);
  10.     char *p2=strtok(NULL,"#");
  11.     // printf("%s\n",p2);
  12.     int i=0;
  13.     do
  14.     {
  15.         if(i==0){
  16.         p[i]=strtok(str,"#");}
  17.         else
  18.         {
  19.             p[i]=strtok(NULL,"#");
  20.         }


  21.     }while(p[i++]!=NULL);   //p[i]!=NULL
  22.     i=0;
  23.     while (p[i]!=NULL)
  24.     {
  25.         printf("%s\n",p[i++]);
  26.     }
  27.    

  28.    



  29. }
复制代码

为什么只能切割一个呢,不知道哪里错了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-12-28 21:21:49 | 显示全部楼层
问题出在你对strtok函数的使用上。首先,你需要将str定义为字符数组而不是字符指针,在C语言中,字符串需要以null结尾,并且使用双引号括起来。所以你应该把char str改为char str[] = "123#ban#123456";。

然后,在第一次调用strtok函数时,应该传入字符串的地址,而不是字符串本身。所以你应该把strtok(str, "#")改为strtok(&str[0], "#")。

此外,当后续调用strtok函数时,应该传入NULL作为第一个参数,以便继续从上一次的位置开始切割字符串。所以你应该把strtok(str, "#")改为strtok(NULL, "#")。

最后,你在使用do-while循环和while循环时出现了重复的逻辑,这样会导致无法正确切割字符串。可以将两段代码合并为一个while循环,像这样:
  1. char str[] = "123#ban#123456";
  2. char *p = strtok(str, "#");
  3. while (p != NULL)
  4. {
  5.     printf("%s\n", p);
  6.     p = strtok(NULL, "#");
  7. }
复制代码

这样你就可以正确地切割字符串并输出结果了。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-27 18:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表