strchr的模拟实现

本文介绍了如何模拟实现C语言中的strchr函数,该函数用于在字符串中查找指定字符的首次出现位置。通过给出的头文件和功能说明,可以理解strchr的工作原理,并提供了一个简单的模拟实现方法。
摘要由CSDN通过智能技术生成
strchr的模拟实现

char strchr(const char _Str,char _Val)
char strchr(char _Str,char _Ch)
头文件:#include <string.h>
功能:查找字符串_Str中首次出现字符_Val的位置
说明:返回首次出现_Val的位置的指针,返回的地址是被查找字符串指针开始的第一个与Val相同字符的指针,如果Str中不存在Val则返回NULL。
返回值:成功则返回要查找字符第一次出现的位置,失败返回NULL

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
strtok函数是C语言中的一个字符串分割函数,它可以将一个字符串按照指定的分隔符进行分割,并返回分割后的子字符串。下面是一个简单的strtok模拟实现: ```c #include <stdio.h> #include <string.h> char* my_strtok(char* str, const char* delim) { static char* p = NULL; if (str != NULL) { p = str; } else { if (p == NULL) { return NULL; } str = p; } char* start = str; while (*p) { if (strchr(delim, *p)) { *p++ = '\0'; return start; } p++; } if (*start == '\0') { return NULL; } else { return start; } } int main() { char str[] = "Hello World! This is a test."; const char delim[] = " "; char* token = my_strtok(str, delim); while (token != NULL) { printf("%s\n", token); token = my_strtok(NULL, delim); } return 0; } ``` 这段代码中的`my_strtok`函数模拟了`strtok`函数的功能。它通过静态变量`p`来保存当前位置,第一次调用时传入字符串指针并保存在`p`中,后续调用传入`NULL`则继续从上次结束的位置开始分割。在每次循环中,它会判断当前字符是否为分隔符,如果是则将其替换为`\0`,并返回上一个分割的子字符串的起始位置。当遇到字符串末尾时,如果上一个分割的子字符串非空,则返回该子字符串,否则返回`NULL`表示已经分割完毕。 这段代码的输出结果为: ``` Hello World! This is a test. ``` 这样就实现了一个简单的strtok模拟函数。注意,这只是一个简单的示例,实际使用时需要考虑更多的边界情况和错误处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿的温柔香

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值