鱼C论坛

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

strtok函数

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

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

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

x
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int main()
{
    char str[]="123#ban#123456"; //strtok
    char *p[10]={NULL};
    char *p1=strtok(str,"#");  //str中将#进行切割返回前面的字符串
    // printf("%s\n",p1);
    char *p2=strtok(NULL,"#");
    // printf("%s\n",p2);
    int i=0;
    do
    {
        if(i==0){
        p[i]=strtok(str,"#");}
        else
        {
            p[i]=strtok(NULL,"#");
        }


    }while(p[i++]!=NULL);   //p[i]!=NULL
    i=0;
    while (p[i]!=NULL)
    {
        printf("%s\n",p[i++]);
    }
    

    



}
为什么只能切割一个呢,不知道哪里错了
想知道小甲鱼最近在做啥?请访问 -> 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循环,像这样:
char str[] = "123#ban#123456";char *p = strtok(str, "#");while (p != NULL){    printf("%s\n", p);    p = strtok(NULL, "#");}
这样你就可以正确地切割字符串并输出结果了。

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-25 22:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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