【C语言】关于字符串函数的使用及模拟实现(1)

一、字符串追加

1.1 库函数srecat的使用

1.2 库函数strncat的使用

1.3 模拟实现库函数 strcat 及 strncat

由上可知,字符串追加的原理是找到所添加字符串的 \0 位置,再对其进行添加。

代码1、

代码2、


二、字符串查找

2.1 库函数strstr的使用

使用strstr函数可以快速的定位到所查找字符串的地址。

2.2 模拟实现库函数 strstr

//模拟实现字符串查找
#include<stdio.h>
char* my_strstr(const char* a,const char* b){
	const char* a1 = a;  
	const char* b1 = b;  
	const char* p = a;    // 记录从字符串a开始查找的位置
	if(*b == '\0'){
		return (char*)a;
	}
	while(*p){
		a1 = p;
		b1 = b;  // 重置指向字符串b的指针
		while(*a1 && *b1 && (*a1 == *b1)){
			a1++;
			b1++;
		}
		if(*b1 == '\0'){ //表示已查完,返回开始查找的位置
			return (char*)p;
		}
	p++;
	}
	return NULL; //未查找到
}

int main(){
	char a[20] = "hongshaorou";
	char b[] = "shao";
	char * ret = my_strstr(a,b);
	if(ret == NULL){
		printf("没找到");
	}else{
		printf("找到了:%s\n",ret);	
	}
	return 0;
}

三、求字符串长度

3.1 库函数strlen的使用

记录 ' \0 ' 之前的字符数。

3.2 模拟实现库函数strlen

注意:在库函数中strlen的返回类型为suze_t(无符号整型),我们这里的返回类型为int型。

代码1

#include<stdio.h>
int my_strlen(const char* a){
	int count = 0;
	while(*a){
		a++;
		count++;
	}
	return count;
}

int main(){
	char a[] = "hello";
	int len = my_strlen(a);
	printf("%d\n",len);
	
	return 0;
}

代码2

#include<stdio.h>
int my_strlen(const char* a){
	const char* p = a;
	while(*a){
		a++;
	}
	return (int)(a-p);
}
int main(){
	char a[] = "hello";
	int len = my_strlen(a);
	printf("%d\n",len);
	return 0;
}
相关推荐
涛ing1 小时前
21. C语言 `typedef`:类型重命名
linux·c语言·开发语言·c++·vscode·算法·visual studio
黄金小码农1 小时前
C语言二级 2025/1/20 周一
c语言·开发语言·算法
7yewh4 小时前
嵌入式知识点总结 C/C++ 专题提升(七)-位操作
c语言·c++·stm32·单片机·mcu·物联网·位操作
egoist20235 小时前
数据结构之堆排序
c语言·开发语言·数据结构·算法·学习方法·堆排序·复杂度
Shimir6 小时前
高并发内存池_各层级的框架设计及ThreadCache(线程缓存)申请内存设计
c语言·c++·学习·缓存·哈希算法·项目
T.Ree.7 小时前
C语言_自定义类型(结构体,枚举,联合)
c语言·开发语言
Tanecious.8 小时前
C语言--数据在内存中的存储
c语言·开发语言·算法
MSTcheng.9 小时前
C语言操作符(上)
c语言·开发语言
卷卷的小趴菜学编程10 小时前
c++之List容器的模拟实现
服务器·c语言·开发语言·数据结构·c++·算法·list
DARLING Zero two♡13 小时前
【初阶数据结构】逆流的回环链桥:双链表
c语言·数据结构·c++·链表·双链表