【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;
}
相关推荐
智者知已应修善业11 分钟前
【51单片机LED贪吃蛇】2023-3-27
c语言·c++·经验分享·笔记·嵌入式硬件·51单片机
福尔摩斯张9 小时前
Axios源码深度解析:前端请求库设计精髓
c语言·开发语言·前端·数据结构·游戏·排序算法
在繁华处9 小时前
C语言经典算法:汉诺塔问题
c语言·算法
Bona Sun10 小时前
单片机手搓掌上游戏机(十一)—esp8266运行gameboy模拟器之硬件连接
c语言·c++·单片机·游戏机
酸钠鈀10 小时前
模拟IIC通讯 基于状态机
c语言
橘子真甜~12 小时前
C/C++ Linux网络编程6 - poll解决客户端并发连接问题
服务器·c语言·开发语言·网络·c++·poll
小年糕是糕手14 小时前
【C++】C++入门 -- 输入&输出、缺省参数
c语言·开发语言·数据结构·c++·算法·leetcode·排序算法
Star在努力15 小时前
C语言复习八(2025.11.18)
c语言·算法·排序算法
赖small强15 小时前
【Linux C/C++开发】第26章:系统级综合项目理论
linux·c语言·c++
仟濹16 小时前
【C/C++】经典高精度算法 5道题 加减乘除「复习」
c语言·c++·算法