函数原型:
参数:
str :需分割的字符串的地址
delimiters :由分割符组成的字符串的地址
返回值:
返回被分割的第一个子字符串地址
若无可检索的字符串则返回空指针(NULL)
函数的使用:
在第一次调用函数时传入字符串,函数会从传入地址开始检索,找到分隔符后将该地址对应的内容改为'\0',并返回被分割的第一个子字符串地址
后续调用时传入空指针—>NULL,函数会从上一次调用所记录的地址(即所找到字符串中的分隔符对应地址的下一位)开始检索,重复上述过程直至检索完整个字符串
需注意,函数使用时会更改所传入的字符串,将分隔符改为'\0',因而在使用函数时一般会创建另一个相同的字符串传入
使用实例
#include<stdio.h>
#include<string.h>
int main()
{
char str[20] = "123456@163.com";
char buf[100];
strcpy(buf, str);
char* pf = "@.";
char* ret = NULL;
for (ret = strtok(buf, pf); ret != NULL; ret = strtok(NULL, pf))
{
printf("%s\n", ret);
}
return 0;
}
函数的模拟实现:
#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strtok(char* str, const char* del)
{
assert(del);
char* del_start = del;//记录del的初始地址
char* str_start = NULL;
static char* p = NULL;
//判断str传入值是否为NULL,若为NUll,则将上一次存下的地址p赋给str
if (str == NULL)
{
if (p == NULL)//若字符串为空,返回NULL
return str_start;
else
str = p;
}
str_start = str;//将str的初始地址保存,便于返回
//逐个检索
while (*str)
{
del = del_start;//重置del
while (*del)
{
if (*str == *del)
{
p = str + 1;//将已查找到的分割符地址的下一位存入p中便于下次使用
*str = '\0';//将分割符改为'\0'
return str_start;
}
del++;
}
str++;
}
//若已经检索完整个字符串
p = NULL;
return str_start;
}
int main()
{
char str[20] = "123456@163.com";
char buf[20];
strcpy(buf, str);
char* pf = "@.";
char* ret = NULL;
for (ret = my_strtok(buf, pf); ret != NULL; ret = my_strtok(NULL, pf))
{
printf("%s\n", ret);
}
return 0;
}
如有不足欢迎提出
感谢阅读~