strlen, strcpy, strcat, strcmp, memset... (字符串操作函数的实现)

标准接口: size_t strlen(const char *src);

size_t mystrlen(const char *src)
{
	assert(src != NULL);
	int len = 0;
	while (*str++ != '\0')
		++len;
	return len;
}

标准接口: char* strcat(char *dst, const char *src);

char* mystrcat(char *dst, const char *src)
{
	assert(dst != NULL && src != NULL);
	char *pTemp = dst;
	while (*pTemp != '\0')
		++pTemp;
	while ((*pTemp++ = *src++) != '\0')
		;
	return dst;
}

标准接口: char* strncat(char *dst, const char *src, size_t n);

char* mystrncat(char *dst, const char *src, size_t n)
{
	assert(dst != NULL && src != NULL);
	int i = 0;
	char *cp = dst;
	while (*cp++)
		;
	cp--;
	while (i++ < n)
	{
		if ((*cp++ = *src++) == '\0')
		{
			return dst;
		}
	}
	*cp = '\0';
	return dst;
}
标准接口: char* strcpy(char *dst, const char *src);

char* mystrcpy(char *dst, const char *src)
{
	assert(dst != NULL && src != NULL);
	char *cp = dst;
	while ((*cp++ = *src++) != '\0')
		;
	return dst;	
}

标准接口: char* strncpy(char *dst, const char *src, size_t n);

char* mystrncpy(char *dst, const char *src, size_t count)
{
	assert(dst != NULL && src != NULL);
	char *cp = dst;
	while (count-- > 0 && (*cp++ = *src++))
		;
	if (count == 0)
		*cp = '\0';
	reutn dst;
}

标准接口: int strcmp(const char *str1, const char *str2);

int mystrcmp(const char *str1, const char *str2)
{
	assert(str1 != NULL && str2 != NULL);
	char *cp1 = str1;
	char *cp2 = str2;
	while (*cp1 && *cp2 && (*cp1 == *cp2))
	{
		cp1++;
		cp2++;
	}
	return (*cp1 - *cp2);
}


标准接口: void* memset(void *ptr, int value, size_t n);

void* memset(void *ptr, int value, size_t n)
{
	assert(ptr != NULL);
	char *cp = ptr;
	while (n-- > 0)
		*cp++ = (char)value;
	return ptr;
}

标准接口: void* memcpy(void *dst, const void *src, size_t n);

void* mymemcpy1(void *dst, const void *src, size_t n)
{
	assert(dst != NULL && src != NULL);
	char *pdst = dst;
	char *psrc = src;
	while (n-- > 0)
		*pdst++ = *psrc++;
	return dst;
}
// If copying takes place between objects that overlap, the behavior is undefined
void* mymemcpy2(void *dst, const void *src, size_t n)
{
	assert(dst != NULL && src != NULL);
	char *pdst = dst;
	char *psrc = src;
	if (psrc < pdst && (pdst < (psrc+n)))	// 自后向前copy
	{
		pdst += (n-1);
		psrc += (n-1);
		while (n-- > 0)
			*pdst-- = *psrc--;
	}
	else
	{
		while (n-- > 0)
			*pdst++ = *psrc++;
	}
	return dst;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值