目录
strlen函数的模拟
strlen函数展示
#include <stdio.h>
#include <string.h>
int main()
{
char arr1[] = {"abcdef"};
int len = strlen(arr1);
printf("%d", len);
return 0;
}
strlen函数模拟
strlen函数计算\0以前的字符有几个
#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* str)//这是为了增加鲁棒性,使原来传过来的不能改
{
assert(str);//防止str的是空的
const char* start = str;
const char* end = str;
while (*end != '\0')
{
end++;
}
return end - start;//start是原来的初始地址
}
int main()
{
char arr[] = {"abcdef"};
int len = my_strlen(arr);
printf("%d", len);
return 0;
}
strcpy函数的模拟
strcpy函数展示
#include <stdio.h>
#include <string.h>
int main()
{
char arr1[20] = {"abcd"};
char arr2[] = {"ccccccc"};
strcpy(arr1, arr2);
printf("%s\n", arr1);
return 0;
}
strcpy函数模拟
strcpy又叫复制函数,将arr2的字符复制到arr1里面
#include <stdio.h>
#include <assert.h>
char* my_strcpy(char* dest, const char* scr)//那个char*是原来strcpy规定的
{
assert(dest);
assert(scr);
char* ret = dest;//把初始地址先存下来,不然直接得到后面的dest早就不是初地址
while (*dest++ = *scr++)
{
;
}
return ret;
}
int main()
{
char arr[20] = { "abc" };
char arr1[] = { "abcdef" };
my_strcpy(arr, arr1);
//printf("%s\n", my_strcpy(arr, arr1));这样也行
printf("%s\n", arr);
return 0;
}
strcat函数的模拟
strcat函数展示
#include <stdio.h>
#include <string.h>
int main()
{
char arr2[] = { "world" };
char arr1[20] = {"hello "};//注意要在目标的里面加入大小[20]
strcat(arr1, arr2);//追加字符
printf("%s\n", arr1);
return 0;
}
strcat函数模拟
strcat函数又叫追加函数,将后面的字符串加到目标字符串后面
#include <stdio.h>
#include <string.h>
char* my_strcat(char* dest, const char* scr)
{
//先找目标空间的‘\0’
char* cur = dest;
while (*cur != '\0')
{
cur++;
}
//拷贝源头数据到'\0'之后的空间
while (*cur++ = *scr++)
{
;
}
return dest;//因为原来的dest没有变,还是初始位置
}
int main()
{
char arr1[20] = {"hello "};
char arr2[] = { "world" };
printf("%s\n", my_strcat(arr1, arr2));
return 0;
}
strcmp函数的模拟
strcmp函数展示
#include <stdio.h>
#include <string.h>
int main()
{
char arr1[] = {"abcd"};
char arr2[] = { "abcdef" };
int ret = strcmp(arr1, arr2);
if (ret > 0)
printf("arr1 > arr2\n");
else if (ret < 0)
printf("arr1 < arr2\n");
else
printf("arr1 = arr2\n");
return 0;
}
strcmp函数模拟
比较函数
第一个比第二个大的返回一个正数
第一个比第二个小返回一个负数
第一个跟第二个一样返回0
#include <assert.h>
int my_strcmp(const char* s1, const char* s2)
{
assert(s1 && s2);//保证s1和s2不为0
while (*s1 == *s2)
{
if (*s1 =='\0')//等于0的时候
{
return 0;
}
s1++;
s2++;
}
return *s1 - *s2;//大于和小于的时候
}
int main()
{
//char arr1[] = { "abc" };
//char arr2[] = { "abcd" };//char arr1[] = { "abcd" };
//char arr2[] = { "abc" };char arr1[] = { "abc" };
char arr2[] = { "abc" };
int ret = my_strcmp(arr1, arr2);
if (ret > 0)
printf("arr1 > arr2\n");
else if (ret < 0)
printf("arr1 < arr2\n");
else
printf("arr1 = arr2\n");
return 0;
}
strstr函数的模拟
strstr函数展示
#include <stdio.h>
int main()
{
char arr1[] = { "abcdef" };
char arr2[] = { "bcd" };
char *p = strstr(arr1, arr2);
if(p == NULL)
{
printf("不存在\n");
}
else
printf("%s\n", p);
return 0;
}
strstr函数模拟
在一个字符串中找另一个字符串是否存在
存在:返回子串第一次所在的位置
不存在:返回NULL
#include <stdio.h>
char* my_strstr(const char* str1, const char* str2)
{
const char* s1 = str1;
const char* s2 = str2;const char* p = str1;
while (*p)//str1不等于\0就可以循环
{
s1 = p;//每次比对完又回来
s2 = str2;//每次比对完又回来
while (*s1 != '\0' && *s2 != '\0' && (*s1 == *s2))
{
s1++;
s2++;
}
if (*s2 == '\0')
{
return (char*)p;//找到了
}
p++;
}
return NULL;//找不到子串;}
int main()
{
char arr1[] = { "abcdef" };
char arr2[] = { "bcd" };
char *p = my_strstr(arr1, arr2);
if(p == NULL)
{
printf("不存在\n");
}
else
printf("%s\n", p);return 0;
}