当前位置: 首页 > news >正文

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

文章目录

  • 前言
  • 1、strlen函数
    • 1.1、strlen函数介绍
    • 1.2、strlen函数的模拟实现
  • 2、strcpy
    • 2.1、strcpy函数介绍
    • 2.2、strcpy的模拟实现
  • 3、strcat
    • 3.1、strcat函数介绍
    • 3.2 strcat函数的模拟实现
  • 4、strstr()
    • 4.1strstr函数介绍
    • 4.2、strstr函数的模拟实现


前言

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


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

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

相关文章:

  • 杭州做网站博客/联合早报 即时消息
  • 网址大全官网下载/北京网站优化指导
  • 网站三网合一案例/营销型网站建设论文
  • dede可以做购物网站吗/新乡网站推广
  • 成品网站源码1688danji6/必应搜索引擎入口
  • 温州企业网站建设/合肥seo排名优化
  • 你就想这样一辈子躺平,还是改变这个世界?
  • 基于 FPGA 读取 AHT10 温湿度数据及 OLED 显示详细工程
  • 面试题-渗透测试实习生
  • windwos上vue开发环境搭建
  • 自然语言处理Transformer模型最详细讲解(图解版)
  • 涂鸦智能三明治音视频核心板(BK7256)开箱测评
  • 800行Python代码实现双十一自动登录抢购商品,这速度女友很爱
  • 13. K近邻模型
  • 【云原生】Spark on k8s 讲解与实战操作
  • 基于Java+SpringBoot+vue+element疫情物资捐赠分配系统设计和实现
  • 拓扑排序算法
  • 五天自学 Compose 从 0 到 1 构建一个 WanAndroid 客户端