✨前言✨
🎓作者:【 教主 】
📜文章推荐:
☕博主水平有限,如有错误,恳请斧正。
📌机会总是留给有准备的人,越努力,越幸运!
💦导航助手💦
目录
strlen函数
头文件:<string.h>
函数原型:
参数:一个指针
作用:传过去一个地址,从这个地址开始的字符串长度
举个例子,代码如下:
#include<stdio.h>
#include<string.h>
int main()
{
char str[] = "abcdef";
int len = strlen(str);
printf("%d\n", len);
return 0;
}
数组名是数组首元素的地址,str即为a的地址,从a开始向后看到了"abcdef\0",不会计算'\0',所以长度应该为6
运行结果如下:
模拟实现strlen
三种方法实现strlen
-
计数器方法
代码如下:
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* p)
{
assert(p);
int len = 0;
while ('\0' != *p)
{
len++;
p++;
}
return len;
}
int main()
{
char str[] = "abcdef";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
因为我们只需要知道字符串的长度,不需要对字符串进行改变,所以形参用一个const char* 来接收地址,并且我们还要防止传过来一个空指针,所以要用到断言assert()函数帮我们检查一下是否为空指针。
运行结果如下:
-
递归
这种方法不需要创建临时变量
代码如下:
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* p)
{
assert(p);
if ('\0' == *p)
return 0;
else
return 1 + my_strlen(p + 1);
}
int main()
{
char str[] = "abcdef";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
运行结果如下:
-
指针相减
我们知道,指针相减可以得到两个指针之间的元素个数,基于这一点,如果我们知字符串的起始地址与结尾地址,两个指针相减就是长度。
代码如下:
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* p)
{
assert(p);
const char* cur = p;
while ('\0' != *cur)
{
cur++;
}
return cur - p;
}
int main()
{
char str[] = "abcdef";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
代码如下:
strcpy函数
头文件:<string.h>
函数原型:
参数:
- str--源字符串
- dest--目标字符串
作用:将str指向的字符串复制到dest指向的空间,如果dest指向的空间不够大可能会造成溢出的请情况。返回目标字符串的起始地址。
举个例子,代码如下:
#include<stdio.h>
#include<string.h>
int main()
{
char str[] = "abcdef";
char dest[20];
strcpy(dest, str);
printf("%s\n", dest);
return 0;
}
运行结果如下:
模拟实现strcpy
将源字符串里的每一个元素赋值给目标字符串的每一个元素即可
代码如下:
#include<stdio.h>
#include<string.h>
#include<assert.h>
void my_strcpy(char* dest, const char* str)
{
assert(dest && str);
while (*dest++ = *str++);
}
int main()
{
char str[] = "abcdef";
char dest[20];
my_strcpy(dest, str);
printf("%s\n", dest);
return 0;
}
运行结果如下:
strcmp函数
头文件:<string.h>
函数原型:
参数:两个字符地址
作用:从左到右比较两个字符串中的每一个字符的大小(比较ASCLL码值),如果前一个字符串大于第二个字符串就返回正数,如果相等就返回0,前一个小于后一个就返回负数。
举个例子,代码如下:
#include<stdio.h>
#include<string.h>
int main()
{
char str1[] = "abcdef";
char str2[] = "abcdeg";
int ret = strcmp(str1, str2);
if (ret < 0)
{
printf("str1 < str2\n");
}
else if (0 == ret)
{
printf("str1 == str2\n");
}
else
{
printf("str1 > str2\n");
}
return 0;
}
因为前5个字符abcde都一样,而f<g,所以结果应该是str1<str2
运行结果如下:
模拟实现strcmp
代码如下:
#include<stdio.h>
#include<assert.h>
#include<assert.h>
int my_strcmp(const char* p, const char* q)
{
assert(p && q);
while (*p == *q)
{
if ('\0' == *p)
return 0;
p++;
q++;
}
return *p - *q;
}
int main()
{
char str1[] = "abcdef";
char str2[] = "abcdeg";
int ret = my_strcmp(str1, str2);
if (ret < 0)
{
printf("str1 < str2\n");
}
else if (0 == ret)
{
printf("str1 == str2\n");
}
else
{
printf("str1 > str2\n");
}
return 0;
}
运行结果如下:
欢迎关注,码字不易,希望多多点赞、收藏哦!抱拳了。