【C语言】-字符串函数和内存函数(上)


前言

重点介绍字符串和字符串函数的使用及注意事项。


1、strlen函数

1.1、strlen函数介绍

我们从cplusplus.com网站上搜寻到strlen函数的介绍
在这里插入图片描述
我们需要注意这个函数接收的数据类型和返回的数据类型。
接收:字符串指针
返回:unsigned int类型的数据
函数功能:计算’\0’前的字符串的长度。起始位置是str指向的那个元素。

1.2、strlen函数的模拟实现

#include<stdio.h>
unsigned int my_strlen(char* str)
{
	char* p = str;
	while (*p)//当p遇到'\0'时跳出循环,因为’\0‘的本质就是0
	{
		p++;
	}
	return p - str;
}
int main()
{
	char arr1[] = "abcdef";
	int num = my_strlen(arr1);
	printf("%d", num);
	return 0;
}

2、strcpy

2.1、strcpy函数介绍

我们从cplusplus.com网站上搜寻到strlen函数的介绍如下图
在这里插入图片描述
接收:第一个接收的参数是目标字符串,第二个接收的参数是源字符串。由于源字符串一般不进行修改,故用const修饰。

返回:返回copy好的目标字符串的地址,便于实现链式访问。

函数功能:将源字符串拷贝到目标字符串里去,包括\0。
那么这里需要注意的是目标空间要足够大,以确保能存下。
另外,如果目标指针指向的是常量字符串,那么是不可以copy的,
例如char* p = “abcdef”。指针p指向的就是一个不可以修改的空间。就不可以传入strcpy函数里作为目标指针。

2.2、strcpy的模拟实现

#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* src)
{
	char* ret = dest;
	assert(dest != NULL);
	assert(src != NULL);
	while (*src != 0)
	{
		*dest = *src;
		dest++;
		src++;
	}
	return ret;//这里不能返回dest,因为dest已经++很多次了,已经没有指向第一个字符了

}
int main()
{
	char arr1[20] = { 0 };
	char arr2 [] = "abcdefg";
	printf("%s",my_strcpy(arr1, arr2));//由于strcpy返回了指针,实现了链式访问
	return 0;
}

执行结果:
在这里插入图片描述

3、strcat

3.1、strcat函数介绍

我们从cplusplus.com网站上搜寻到strlen函数的介绍如下图
在这里插入图片描述
接收:需要被追加字符串的字符串指针,追加的源字符串。由于追加的源字符串一般不进行改变,故用const修饰

返回:被追加完成后的字符串。

函数功能:可以将一个字符串追加到另外一个字符串后面,需要注意的是,被追加的字符串的\0会被源字符串的第一个字符替换掉。字符串必须要有\0作为结束的标志。被追加的字符串需要有足够大的空间,确保能接收下被追加后的字符串。

3.2 strcat函数的模拟实现

在这里插入图片描述
这是笔者通过思考画出的粗糙简陋的思路图。(比较抽象,看不懂没关系)。

#include<stdio.h>
#include<assert.h>
char* my_strcat(char* dest, const char* src)
{
	char* ret = dest;
	assert(dest != NULL);
	assert(src != NULL);
	while (*dest)//注意,这里不可以把dest++放到这里,变成*dest++,因为如果放到这里的话,循环跳出之后dest还会跳过\0,这样会导致\0在后面没有被修改掉。
	{
		dest++;
	}
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}
int main()
{
	char arr1[20] = "abcdefg";
	char arr2[] = "hijklmn";
	printf("%s", my_strcat(arr1, arr2));
	return 0;
}

运行结果:
在这里插入图片描述

4、strstr()

4.1strstr函数介绍

我们从cplusplus.com网站上搜寻到strlen函数的介绍如下图
在这里插入图片描述
接收:两个字符串指针

返回:返回字符串第一次存在的地址

作用:在一串字符串里查找另一个字符串的存在,若存在,则返回第一次出现的位置的地址,若不存在,则返回null。

4.2、strstr函数的模拟实现

#include<stdio.h>
char* my_strstr(const char* str1, const char* str2)
{

	
		char* p = (char*)str1;
		char* s1, * s2;
		if (!*str2)
			return((char*)str1);
		while (*p)
		{
			s1 = p;
			s2 = (char*)str2;
			while (*s1 && *s2 && !(*s1 - *s2))
				s1++, s2++;
			if (!*s2)
				return(p);
			p++;
		}
	
}
int main()
{
	char arr1[] = "abcdefghi";
	char arr2[] = "cde";
	printf("%s", my_strstr(arr1, arr2));
	return 0;
}

运行结果:
在这里插入图片描述
这段代码有点难度需要反复琢磨。

评论 44
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Dontflinch

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

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

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

打赏作者

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

抵扣说明:

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

余额充值