C语言实现各类string函数

1.实现strcpy(字符串复制)

函数原型:char strcpy(char dest, const char src);
strcpy把含有’\0’结束符的字符串复制到另一个地址空间,返回值的类型为char

代码:

#include<stdio.h>
#include<windows.h>
#include<assert.h>

char* my_strcpy(char *des, char const *stc)
{
	assert(des != NULL);
	assert(stc != NULL);
	char* res = des;
	while (*stc){
		*des = *stc;
		stc++;
		des++;
	}
	return res;
}

int main()
{
	char str1[100] = { 0 };
	char *str2 = "i am wangwenqian.";
	my_strcpy(str1, str2);
	printf("%s\n", str1);
	system("pause");
	return 0;
}

2.实现strcat

函数原型:extern char strcat(char dest, const char src);
功能:把src所指向的字符串(包括“\0”)复制到dest所指向的字符串后面(删除
dest原来末尾的“\0”)。要保证
dest足够长,以容纳被复制进来的
src。*src中原有的字符不变。返回指向dest的指针。
说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。

代码:

#include<stdio.h>
#include<windows.h>
#include<assert.h>

char* my_strcat(char *des, char const *stc)
{
	char* ret = des;
	assert(des != NULL);
	assert(stc != NULL);
	while (*des){   //des指向\0
		des++;
	}
	while (*stc){  //拼接stc
		*des = *stc;
		des++;
		stc++;
	}
	return ret;
}

int main()
{
	char str1[100] = "abc";
	char *str2 = "cdefg";
	my_strcat(str1, str2);//str1实际传址
	printf("%s\n", str1);
	system("pause");
	return 0;
}

3.实现strstr

函数原型:extern char *strstr(char *str1, const char *str2);
strstr(str1,str2) 函数用于判断字符串str2是否是str1的子串。如果是,则该函数返回str2在str1中首次出现的地址;否则,返回NULL。

代码:

#include<stdio.h>
#include<windows.h>
#include<assert.h>

char* my_strstr(const char *str1, const char *str2)
{
	assert(str1);
	assert(str2);
	char *ret = (char *)str1;
	char *res = (char *)str2;
	while (*ret){
		char cp = (char *)str1;
		if (*ret == *res && *res != '\0'){  //当*ret与*res相等且*res不为0时,俩个指针同时向后移动
			ret++;
			res++;
		}
			if (*res == "\0"){  //*res为0,说明满足了上一个if条件,且找到字串
			return cp;
		}
		if (*ret == '\0'){  //*ret为\0,表示其一直向后移动,说明并没有找到字串
			return NULL;
		}
		ret++;  //让ret一直向后移动
	}
}

int main()
{
	char *str1 = "question";
	char *str2 = "tion";
	char *ret = my_strstr(str1, str2);
	printf("%p\n",ret );
	system("pause");
	return 0;
}

4.实现strchr

函数原型:extern char *strchr(const char *s,char c)
可以查找字符串s中首次出现字符c的位置。

代码:

#include<stdio.h>
#include<stdlib.h>

char * my_strchr(const char * str, char c)
{
	while (*str != '\0' &&  *str != c){
		str++;
	}
	return str;
}

int main()
{
	char arr[] = "student";
	char c = 'u';
	char *ret = my_strchr(arr, c);
	printf("%s\n", arr);
	system("pause");
	return 0;
}

5.实现strcmp

函数原型:extern int strcmp(const char *s1,const char *s2);
比较俩个字符串。若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数。

#include<stdio.h>
#include<windows.h>
#include<assert.h>

int strcmp(const char *str1, const char *str2)
{
	assert(str1);
	assert(str2);
	while (*str1 && (*str1==*str2)){
		str1++;
		str2++;
	}
	if ((*(unsigned char *)str1) > (*(unsigned char *)str2))
		return 1;
	else if ((*(unsigned char *)str1) < (*(unsigned char *)str2))
		return -1;
	else
		return 0;
}

int main()
{
	char *str1 = "abcd";
	char *str2 = "abcdef";
	int ret = strcmp(str1, str2);
	printf("%d\n", ret);
	system("pause");
	return 0;
}

6.实现memcpy

函数原型:void *memcpy(void *dest, const void *src, size_t n);
从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中。

代码:

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#define N 20

char * my_memcpy(char *des, char *stc, int len)
{
	assert(des);
	assert(stc);
	char *res = des;
	while (len--){
		*des = *stc;
		des++;
		stc++;
	}
	return res;
}

int main()
{
	char arr1[N] = "";
	char arr2[N] = "i am a student";
	my_memcpy(arr1, arr2, 6);
	printf("%s\n",arr1);
	system("pause");
	return 0;
}

7.实现memmove

函数原型:void memmove( void dest, const void* src, size_t count );
memmove用于拷贝字节,如果目标区域和源区域有重叠的话,memmove能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,但复制后源内容会被更改。但是当目标区域与源区域没有重叠则和memcpy函数功能相同。

代码:

#include<stdio.h>
#include<stdlib.h>
#define N 20

char *my_memmove(char *des, char *str, int len)
{
	void *ret = des;
	//无内存重叠
	if (des <= str || des >= str + len){  
		while (len--){
			*des = *str;
			des++;
			str++;
		}
	}
	else{
		des += (len - 1);
		str += (len - 1);
		while (len--){
			*des = *str;
			des--;
			str--;
		}
	}
	return ret;
}

int main()
{
	char arr1[N] = "123456789";
	my_memmove(arr1+3, arr1, 5);
	printf("%s\n", arr1);
	system("pause");
	return 0;
} 

memmove代码比较难懂,建议大家在纸上画一下。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值