str函数的模拟(包括strn函数的模拟)

首先先说这些函数引用的头文件是<string.h>

1.strlen函数

int my_strlen(char* s1) {

//这里只用最难的方法

if (*s1) {

return my_strlen(s1 + 1) + 1;

}

else

return 0;

}

这里使用了递归 的方法**(不创建新的变量)** ,如果需要看指针,数组用计数器count**(创建新变量)**的方法看之前发的文章string函数的模拟即可;

讲解一下这个函数的作用:这个函数能求解'\0'之前元素个数,直到找到'\0',如果找不到就会生成随机数。

注意点:这些str函数返回值一般都是unsigned int 类型,但是我的模拟函数都是返回int型,如果用库函数的话,做减法要注意不会出现负值。


2.strcpy函数

void my_strcpy(char* s1, const char* s2) {

assert(s1 && s2);

while (*s1++ = *s2++)//这里可以刚好把'\0'给拷贝过去然后出来

;

}

该函数的功能就是将一个字符串的内容进行拷贝到另一个字符串,为啥不直接使用赋值呢?

char str[20]="abcd";

str="abcd";这样是错误的,因为现在的str代表的是字符串首元素的地址,是没办法直接进行赋值的;

注意:要看好传入的是啥,前面的是要拷贝的位置,后面那个是要拷贝内容的地址;


3.strcat函数

void my_strcat(char* s1, const char* s2) {

assert(s1 && s2);

while (*s1++)

;

s1--;

while (*s1++ = *s2++)

;

}

该函数的作用是将一段字符串加在另外一段字符串的后面;


4.strstr函数

char* my_strstr(const char* s1, const char* s2) {

while (*s1) {

char* p = s1;

char* new_s2 = s2;

while (*p == *new_s2 && *new_s2 != '\0' && *p != '\0') {

p++;

new_s2++;

}

if (*new_s2 == '\0') {

return s1;

}

s1++;

}

return NULL;

}

这个函数的作用是判断是否为字串后,返回开始符合字串到结尾所在的所有剩余字符;


6.strtok函数

#define _CRT_SECURE_NO_WARNINGS 1//不加上会报错

int main() {

char str1[] = "www.baidu@com";

char* str = "@.";

char* ret = NULL;

char str2[20] = {0};

strcpy(str2, str1);

ret = strtok(str2, str);

printf("%s\n", ret);

ret = strtok(NULL, str);

printf("%s\n", ret);

ret = strtok(NULL, str);

printf("%s\n", ret);

ret = strtok(NULL, str);

printf("%s\n", ret);

return 0;

}

strtok有两种机制:

1.如果strtok不为NULL,那么会保存@的位置(@会被改成\0)

2.如果strtok为 NULL,那么会从上次strtok所保存@的位置,继续往下找seq中的字符,如果找到,接着分割。最后再保存被改成\0的位置。

最后:如果strtok找到了没被改的\0,也就是字符串末尾的\0时,返回NULL。


7.strncpy函数

char* my_strncpy(char* s1, const char* s2,int count) {

assert(s1&& s2);

char* s1_new = s1;

while (count && (*s1_new++ = *s2++) != '\0') {

count--;

}

if (count) {

while (--count) {//这里先减减是因为上面在离开循环的时候已经处理过一次了,但是没有count--;这样处理之后循环能少一次

*s1_new++ = '\0';

}

}

return s1;

}

这个函数可以确定控制要拷贝的个数,如果供给拷贝的字符串短于要拷贝的个数,剩余的使用'\0'进行补充。


8.strncat函数

char* my_strncat(char* s1, const char* s2, int count) {

assert(s1 && s2);

char* start = s1;

while (*s1++)

;

s1--;

while (count--) {

if ((*s1++ = *s2++) == '\0')

return (start);

}

*s1 = '\0';

return (start);

}

这个的逻辑是加到出现'\0'就直接return离开,如果还没有出现'\0'最后给截止的'\0'再离开,返回的是一个字符串首元素的地址。

相关推荐
电鱼智能的电小鱼4 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun4 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书5 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector6 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会6 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗6 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚6 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实6 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证9 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
电院工程师9 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学