C语言:模拟实现strlen strcpy strcmp

✨前言✨

🎓作者:【 教主 】

📜文章推荐:

☕博主水平有限,如有错误,恳请斧正。

📌机会总是留给有准备的人,越努力,越幸运!

💦导航助手💦

目录

strlen函数

模拟实现strlen

计数器方法

 递归

 指针相减

strcpy函数

模拟实现strcpy 

strcmp函数

模拟实现strcmp


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;
}

运行结果如下:


欢迎关注,码字不易,希望多多点赞、收藏哦!抱拳了。

评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

【 Stack_OverFlow 】

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

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

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

打赏作者

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

抵扣说明:

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

余额充值