模拟实现strncpy、strncat、strncmp

1..模拟实现strncpy 

原型声明:char *strncpy( char *strDest, const char *strSource, size_t count );

功能:把strSource所指向的字符串中以strDest地址开始的前n个字节复制到strDest所指的数组中,并返回strDest

这里值得注意的是:此拷贝并不会将'\0'拷到目标字符串中


接下来我们自己实现此函数:

char *my_strncpy(char *dest, char *src, int n)
{
	assert(dest);
	assert(src);
	char *p = dest;
	while (n--)
	{
		*dest = *src;
		dest++;
		src++;
	}
	return (char*)p;
}
int main()
{
	char str1[] = "abcdefg";
	char str2[] = "12345";
	my_strncpy(str1, str2, strlen(str2) + 1);
	printf("%s\n", str1);
	system("pause");
	return 0;
}

此时再传参数时,给strlen+1,说明将'\0'传了过去,因此改变的原字符串的长度

看看运行结果吧:


2.模拟实现strncat

原型:char * strncat(char *dest, const char *src, size_t n);

功能:把src所指字符串的前n个字符添加到dest所指字符串的结尾处,并覆盖dest所指字符串结尾的'\0',从而实现字符串的连接

char *my_strncat(char *dest, char *src, int n)
{
	assert(dest);
	assert(src);
	char *p = dest;
	while (*dest)
	{
		dest++;
	}
	while (n--)
	{
		*dest = *src;
		dest++;
		src++;
	}
	dest = '\0';
	return (char*)p;
}
int main()
{
	char str1[30] = "abcdefg";
	char str2[30] = "12345";
	my_strncat(str1, str2, 4);
	//my_strncpy(str1, str2, 2);
	printf("%s\n", str1);
	system("pause");
	//return 0;
}

运行结果:


3.模拟实现strncmp

原型:int strncmp ( const char * str1, const char * str2, size_t num );

功能:这个函数用来比较s1和s2字符串的前maxlen个字符。如果两个字符串相等的话,strncmp将返回0。如果s1是s2的一个子串的话,s1小于s2。此外还有,函数 int strncmp (const char *s1, const char *s2, size_t size) 此函数与strcmp极为类似。不同之处是,strncmp函数是指定比较size个字符。也就是说,如果字符串s1与s2的前size个字符相同,函数返回值为0。

也就是b比较到另个字符不一样或者字符串结束或者num个字符全部比较完

看看代码吧

int my_strncmp(const char *str1, const char *str2, int n)
{
	assert(str1);
	assert(str2);
	int ret = 0;
	while (!(ret = *(unsigned int*)str1 - *(unsigned int*)str2)&& n && str1)
	{
		str1++;
		str2++;
		n--;
	}
	if (ret > 0)
	{
		return 1;
	}
	else if (ret < 0)
	{
		return -1;
	}
	else
	{
		return 0;
	}
}
int main()
{
    const char str1[30] = "abcde";
	const char str2[30] = "abcfw";
	printf("%d\n", my_strncmp(str1, str2,3));
	system("pause");
	return 0;
}
运行结果:


这里我们在看看这个代码,计算出他们之间的差值:

int my_strncmp(const char *str1, const char *str2, int n)
{
	assert(str1);
	assert(str2);
	while (n && (*str1 == *str2))
	{
		if (str1 == '\0')
			return 0;
		str1++;
		str2++;
		n--;
	}
	return *str1 - *str2;
	
}

猜你喜欢

转载自blog.csdn.net/z_juan1/article/details/80407640
今日推荐