用C语言实现一些常见的库函数

一、模拟实现strlen

strlen可以计算字符串的长度,就是从字符串首元素开始,直到' \0 '

cpp 复制代码
int my_strlen(char* str)
{
	assert(str);
	int count = 0;
	while (*str)
	{
		str++;
		count++;
	}
	return count;
}

int main()
{
	char arr[] = "abcdef";
	int len = my_strlen(arr);
	printf("%d", len);
	return 0;
}

法二:

cpp 复制代码
//不创建临时变量

int my_strlen(char* str)
{
	if (0 == *str)
	{
		return 0;
	}
	else
		return 1 + my_strlen(str + 1);
}

法三:

cpp 复制代码
//指针
int my_strlen(char* str)
{
	char* p = str;
	while (*str)
	{
		str++;
	}
	return str - p;
}

二、模拟实现strcpy

strcpy可以将想拷贝的字符串拷贝到指定地点

cpp 复制代码
char* my_strcpy(char* dest, const char* scr)
{
	assert(dest && scr);
	char* ret = dest;
	while (*dest++ = *scr++)
		;
	return ret;
}

int main()
{
	char arr1[] = "abcdef";
	char arr2[10] = { 0 };
	my_strcpy(arr2, arr1);
	printf("%s", arr2);
	return 0;
}

也可以这样用

cpp 复制代码
	my_strcpy(arr2, "我好帅");
	printf("%s\n", arr2);

三、模拟实现strcat

strcat可以实现在字符串后面加上自己想要的字符,直到' \0 '

cpp 复制代码
char* my_strcat(char* dst, char* scr)
{
	assert(dst && scr);
	char* ret = dst;
	while (*dst)
		dst++;
	while (*dst++ = *scr++)
		;
	return ret;
}

int main()
{
	char arr1[20] = "hello ";
	char arr2[] = "blog!";
	my_strcat(arr1, arr2);
	printf("%s", arr1);
	return 0;
}

四、模拟实现strstr

strstr可以寻找字符串中的字符串

cpp 复制代码
char* my_strstr(const char* dst, const char* scr)
{
	char* s1 = (char*)dst;
	char* s2 = (char*)scr;
	char* ret = (char*)dst;
	if (!*s2)
	{
		return ret;
	}
	while (*ret)
	{
		s1 = ret;
		s2 = (char*)scr;
		while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
		{
			return ret;
		}
		ret++;
	}
	return NULL;
}

int main()
{
	char arr1[] = "abbbcde";
	char arr2[] = "bbc";
	char *ret = my_strstr(arr1, arr2);
	printf("%s", ret);
	return 0;
}

五、模拟实现strcmp

strcmp可以实现两个字符串比较,若s1大于s2返回一个大于0的数字,反之返回小于0的数字,若s1=s2,返回0

cpp 复制代码
int my_strcmp(const char* str1,const char*str2)
{
	assert(str1 && str2);
	while (*str1 && *str2 && *str1 == *str2)
	{
		str1++;
		str2++;
	}
	if (!*str1 && !str2)
	{
		return 0;
	}
	return *str1 - *str2;
}

int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "acbdf";
	int ret = my_strcmp(arr1,arr2);
	printf("%d\n", ret);
	return 0;
}

六、模拟实现memcpy

memcpy和strcpy类似,只是strcpy只可以拷贝字符串的,而memcpy可以拷贝其他你想要的类型

cpp 复制代码
void* my_memcpy(void* dst, void* scr, int sz)
{
	void* ret = dst;
	while(sz)
	{
		*(char*)dst = *(char*)scr;
		dst = (char*)dst + 1;
		scr = (char*)scr + 1;
		sz--;
	}
	return ret;
}

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	my_memcpy(arr2, arr1,sizeof(arr1));
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr2[i]);
	}
	printf("\n");
	return 0;
}

七、模拟实现memmove

前面写的memcpy有点小瑕疵,当我想把数组arr1中的12345拷贝到数组arr1的34567上就会出现问题

原因是要拷贝3的时候,3已经被前面的1覆盖了,memmove就可以实现拷贝时重叠的问题

cpp 复制代码
void* my_memmove(void* dst, void* scr, int sz)
{
	assert(dst && scr);
	void* ret = dst;
	if (*(char*)dst > *(char*)scr)
	{
		while (sz+1)
		{
			*((char*)dst + sz) = *((char*)scr + sz);
			sz--;
		}
		return ret;
	}
	else
	{
		while (sz)
		{
			*(char*)dst = *(char*)scr;
			dst = (char*)dst + 1;
			scr = (char*)scr + 1;
			sz--;
		}
		return ret;
	}
}

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	my_memmove(arr1+2, arr1,20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	printf("\n");
	return 0;
}

分类解决一下就好啦~

C语言中还有许多好用的库函数,合理运用可以使我们的代码学习事半功倍,模拟实现库函数也是和前辈大佬们对话的过程

都看到这里啦,就浅浅三连一下啦!QAQ

相关推荐
Darkwanderor5 小时前
插入排序——希尔排序
c语言·算法·排序算法·希尔排序
沐泽Mu6 小时前
嵌入式学习-C嘎嘎-Day04
c语言·开发语言·c++·学习
挥剑决浮云 -7 小时前
Linux 网络编程
linux·运维·c语言·网络·笔记
析木不会编程7 小时前
【数据结构】【线性表】循环链表(附C语言源码)
c语言·数据结构·链表
写bug的小屁孩7 小时前
基于HTTP编写ping操作
服务器·c语言·网络·c++·网络协议·http·qt6.3
奈葵9 小时前
C语言字符函数和字符串函数
c语言·开发语言
OKkankan9 小时前
单链表算法题(数据结构)
c语言·数据结构·数据库·c++·算法
芒 种9 小时前
深入理解指针
c语言
羊小猪~~10 小时前
C/C++语言基础--initializer_list表达式、tuple元组、pair对组简介
c语言·开发语言·c++·vscode·list·c++20·visual studio
t5y2210 小时前
【C语言】Union
c语言·开发语言·算法