strtok()函数

article/2025/10/12 15:40:00

strtok()

将字符串拆分成tokens,tokens是被分隔符中的任何字符分隔的连续字符序列

char* strtok( char* str,const char* sep );

  • sep参数是个字符串,定义了用作分隔符的字符集合
  • 第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
  • strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存其在字符串中的位置。
  • 如果字符串中不存在更多的标记,则返回 NULL 指针。

工作原理:

strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。

(注: strtok函数会改变被操作的字符串(置\0操作),所以在使用strtok函数切分的字符串一般都是临时拷贝的内容 并且可修改。)

如下一段代码

char arr[] = "Atsuki@yeah.net";
const char* sep = "@.";
strtok(arr,sep);//从字符串头开始找第一个标记
strtok(NULL,sep);//从保存好的位置开始继续往后找
strtok(NULL,sep);//从保存好的位置开始继续往后找

strtok会从arrA开始找一直到分隔符@,找到后就会将@置为\0并记住这个位置,然后返回Atsuki字段的首地址,即A的地址。

strtok(arr,sep);执行后字符串就变为了

char arr[] = "Atsuki\0yeah.net";

然后strtok(NULL,sep);就会返回y的地址,并把.置为\0

下一个strtok(NULL,sep);会返回n的地址

如果再调用strtok(NULL,sep);就返回空指针
在这里插入图片描述
但是

一般我们会用将strtok作用在待切分字符串的临时拷贝上,因为它会改变原字符串,并且我们把上面的代码改进一下就是这样的

int main()
{char arr[] = "Atsuki@yeah.net";const char* sep = "@.";char buff[30] = {0};strcpy(buff,arr);char* str = NULL;for(str=strtok(buff,sep); str!=NULL; str=strtok(NULL,sep)){printf("%s\n", str);}return 0;
}

请添加图片描述


http://chatgpt.dhexx.cn/article/u52sUnTE.shtml

相关文章

strtok函数的基本使用

strtok函数的基本使用 一、功能及解释:strtok函数的简单运行strtok函数的基本使用 strtok的函数原型: char* strtok (char* str, const char* sep) 一、功能及解释: 1.包含在string.h头文件中 2.sep是个字符串,定义了用作分隔符…

关于函数strtok和strtok_r的使用要点和实现原理(一)

strtok函数的使用是一个老生常谈的问题了。该函数的作用很大,争议也很大。以下的表述可能与一些资料有区别或者说与你原来的认识有差异,因此,我尽量以实验为证。交代一下实验环境是必要的,winxpvc6.0,一个极端平民化的…

strtok函数

头文件 string.h 函数声明 char * strtok (char * str,const * sep) 返回值 分隔符之前字符串的首地址 用法 sep的参数是个字符串,定义了用作分隔符的字符集合str指定一个字符串,它包含了一个或多个sep中分隔符分割的…

C语言strtok()函数详解

函数原型 char *strtok(char *str, char const *sep);第一次调用strtok函数时,这个函数将忽略间距分隔符并返回指向在str字符串找到的第一个符号的指针,丢掉分隔符sep,添加NULL字符结尾(可以理解为用NULL替换了sep). 通过调用一系列的strtok函数,更多的…

数据库面试题——内连接与外连接、左连接与右连接的区别

内连接与外连接的区别: 1、连接结果不同 内连接的连接结果仅包含符合连接条件的行,参与连接的两个表都必须符合连接条件;而外连接的连接结果不仅包含了符合连接条件的行,同时还包括不符合自身条件的行,其中还包括左外连接、右外连…

sql中内连接和外连接的区别

对于两张表,外连接和内连接的区别在于: 内连接:只显示两表id匹配的左外连接:显示join左边的表的所有数据(不管两表是否匹配),对于不匹配的部分都用NULL显示右外连接:与左外连接相反…

左连接 ,右连接,内连接和全外连接的4者区别

基本定义: left join (左连接):返回包括左表中的所有记录和右表中连接字段相等的记录。 right join (右连接):返回包括右表中的所有记录和左表中连接字段相等的记录。 inner join (等…

数据库中的内连接、自然连接和外连接的区别

数据中的连接join分为内连接、自然连接、外连接,外连接又分为左外连接、右外连接、全外连接 当然,这些分类都是在连接的基础上,是从两个表中记录的笛卡尔积中选取满足连接的记录。笛卡尔积简单的说就是一个表里的记录要分别和另外一个表的记…

交叉连接、内连接和外连接的区别及使用方式

一、交叉连接、内连接、外连接的区别 交叉连接又叫’笛卡尔积’,它是指不使用任何条件,直接将一个表的所有记录和另一个表中的所有记录一一匹配。内连接 则是只有条件的交叉连接,根据某个条件筛选出符合条件的记录,不符合条件的记…

内连接与外连接区别

内连接:指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。 外连接:连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。 左外连接:左边表数据行全部保留…

mysql 内连接、自然连接、外连接的区别

数据库中的内连接、自然连接、外连接 注意:mysql不支持全外连接,using和on的区别在于需要连接的两个表的属性名相同的时候使用using和on效果一样,而属性名不同的时候必须使用on 数据库中的连接join分为内连接、自然连接、外连接&#xff0c…

mysql 自然连接、内连接、外连接的区别

数据库中的连接join分为内连接、自然连接、外连接,外连接又分为左外连接、右外连接、全外连接(注意:mysql不支持全外连接) 首先,我们先来建两张表,第一张表命名为kemu,第二张表命名为score: 一、left join…

内连接与外连接的区别

有两个表A和表B。表A结构如下:Aid:int;标识种子,主键,自增IDAname:varchar数据情况,即用select * from A出来的记录情况如下图1所示:图1:A表数据表B结构如下:Bid&#xf…

内连接、左外连接与右外连接的区别及作用介绍

SQL语句当中比较难的部分就有今天要给朋友们分享的这个,inner join, left join 和 right join他们三个的作用以及区别是什么。 顺便也会把交叉连接一起分享了。 上面会分享一些基本的语法与使用,下方会详细介绍 1)交叉连接,又称笛…

图解数据库左连接、右连接、内连接、外连接、全连接的区别

数据库连表方式 内连接 :inner 、inner join外连接 :outer join 左外连接 :left outer join左连接 :left join右外连接 right outer join右连接: right join 全连接 full join 、union 准备 现在有2张表&#xff0c…

内链接和外连接的区别

内连接,也被称为自然连接,只有两个表相匹配的行才能在结果集中出现。返回的结果集选取了两个表中所有相匹配的数据,舍弃了不匹配的数据。由于内连接是从结果表中删除与其他连接表中没有匹配的所有行,所以内连接可能会造成信息的丢…

数据库的内连接和外连接的区别

内连接:指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。 外连接:连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。 左外连接:左边表数据行全部保留…

内连接和外连接区别

在之前,我对MSSQL中的内连接和外连接所得出的数据集不是很清楚。这几天重新温习了一下SQL的书本,现在的思路应该是很清楚了,现在把自己的理解发出来给大家温习下。希望和我一样对SQL的连接语句不太理解的朋友能够有所帮助。(发这么…

数据库中的内连接、自然连接、和外连接的区别

数据中的连接join分为内连接、自然连接、外连接,外连接又分为左外连接、右外连接、全外连接 当然,这些分类都是在连接的基础上,是从两个表中记录的笛卡尔积中选取满足连接的记录。笛卡尔积简单的说就是一个表里的记录要分别和另外一个表的记…

左右连接和内连接的区别

首先,我这有两个表,里面的数据去这样的: 表和数据准备好了,接下来进行操作: (1)先说左连接查询: 左连接:在 LEFT JOIN 左边的表里面数据全被全部查出来,右边的…