strcpy, strcmp, strcat, strstr, strlen的实现

有时候突然让自己写这些代码,却写不出来或者写不正确或者写的有缺陷,这真心让自己覺得非常搓!所以花了點時間重新自己實現一遍!!!!!!错误处理仅仅检查输入指针空则抛出异常,自己測試過,但也許還是會有bug。以下代码仅供自己参考,若要非常非常准确代码,请君自行百度之 ~ 


//src长度大于dest长度会导致程序崩溃
char* re_strcpy(char* dest, const char* src)
{
	if(!dest || !src) throw "Invalid Argument!";
	
	char* retAddr = dest;

	while( *dest++ = *src++ );

	return retAddr;
}

//一般没有问题
unsigned int re_strlen(const char* str )
{
	if (!str) throw "Invalid Argument!";

	int nLength = 0;

	while(*str++) ++nLength;

	return nLength;
}

char* re_strstr( const char* str1, const char* str2 )
{
	if(!str1 || !str2) throw "Invalid Argument!";
	
	char* pStr1 = (char*)str1;
	char* pStr2 = (char*)str2;
	while(*str1)
	{
		for ( ; *str1 && *str2 && *str1 == *str2; ++str1, ++str2);

		if (*str2 == 0) return pStr1;
		
		str1 = ++pStr1;
		str2 = pStr2;
	}

	return 0;

}

int re_strcmp( const char* str1, const char* str2 )
{
	if (!str1 || !str2) throw "Invalid Argument!";

	int retValue = 0;
	while( !( retValue = *str1 - *str2 ) &&  *str1++ && *str2++ );

	if (retValue > 0)
	{
		retValue = 1;
	}
	else if (retValue < 0)
	{
		retValue = -1;
	}

	return retValue;
}




//dest+src的长度过长会导致程序崩溃
char* re_strcat( char* dest, const char* src )
{
	if(!dest || !src) throw "Invalid Argument!";

	char* retAddr = dest;

	while(*dest) ++dest;

	while( *dest++ = *src++);

	return retAddr;

}


好的,我很乐意为您介绍C语言中strcpystrcatstrcmpstrstr这几个标准库函数的实现方式。这些函数都是操作字符串的常用函数,下面我将逐一为您解释它们的实现原理: 1. strcpy(字符串复制): ```c char *strcpy(char *dest, const char *src) { char *ret = dest; while ((*dest++ = *src++) != '\0'); return ret; } ``` 这个函数逐个字符复制src指向的字符串到dest指向的内存位置,直到遇到字符串结束符'\0'。 2. strcat(字符串连接): ```c char *strcat(char *dest, const char *src) { char *ret = dest; while (*dest != '\0') dest++; while ((*dest++ = *src++) != '\0'); return ret; } ``` 这个函数首先将dest指针移动到字符串末尾,然后将src指向的字符串逐个字符复制到dest的末尾。 3. strcmp(字符串比较): ```c int strcmp(const char *s1, const char *s2) { while (*s1 && (*s1 == *s2)) { s1++; s2++; } return *(unsigned char *)s1 - *(unsigned char *)s2; } ``` 这个函数逐个字符比较两个字符串,直到遇到不同的字符或者字符串结束符。返回值表示两个字符串的关系。 4. strstr(子字符串查找): ```c char *strstr(const char *haystack, const char *needle) { if (!*needle) return (char *)haystack; for (; *haystack; ++haystack) { if (*haystack == *needle && strncmp(haystack, needle, strlen(needle)) == 0) return (char *)haystack; } return NULL; } ``` 这个函数在主字符串(haystack)中查找子字符串(needle)第一次出现的位置。它使用strncmp函数来比较子字符串。 这些实现方式都是标准库函数的基本实现原理。在实际使用中,建议使用标准库提供的函数,因为它们通常经过优化,并且考虑了各种边界情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值