C语言字符串常见的几个函数(下)~

152 阅读5分钟

详解字符串追加函数:strcat的使用及模拟实现!!!

对于字符串,有着千奇百怪的使用方法!在前篇文章,笔者讲解了:字符串统计:字符串统计:strlen函数的讲解,及其模拟实现!!紧接着还有:字符串拷贝函数:strcpy的详解及模拟实现!!!笔者一脸忧愁!!太多了,其实我也记不清楚!!只能大概,也许,可能……嗯

话不多说,我们来进入今天的正题部分!!

笔者查阅资料可得:对于strcat函数的使用方法为:

40081c7042004fcdacb9ea7f9f941103.png char * strcat ( char * destination, const char * source );

在上述的使用说明中:destination 是指:目的地!source是指源头!因此本段的主要内容是:将源头追加到目的地的后面!!

下面笔者来带领大家简单实现一下:对一个字符串:arr1[20]="hello",在其后面追加另外一共字符串“wang" ,变为:”hello wang"; 下面请看笔者的代码:

#include <stdio.h>
#include <string.h>
 
int main()
{
	char arr1[20] = "hello ";
	char arr2[] = "wang";
	strcat(arr1, arr2);
	//字符串追加函数!
	printf("%s\n", arr1);
	return 0;
}

对于上述代码的运行结果也是显而易见的:

cbf0423d329349e99e1dbf14f59a0c78.png 但是,在“world"后面的'\0'是否也能追加在”hello "的后面呢??这个就需要我们进行调试来观察了!!我们可以将arr1[20]初始化为: char arr1[20]="hello \0xxxxxxxxxxx";因此代码为:

#include <stdio.h>
#include <string.h>
 
int main()
{
	char arr1[20] = "hello \0xxxxxxxxxxxx";
	char arr2[] = "wang";
	strcat(arr1, arr2);
	//字符串追加函数!
	printf("%s\n", arr1);
	return 0;
}

对代码进行调试:

e97f8b2a1e1a421d938bde5cedbad2e5.png 调试结束时的运行结果为:

8a5859fda96241498c905cd4fb50abe2.png 结合调试的结果,我们可以看出:‘\0'也进行了追加!!

代码的运行结果为:

a631d4878fe342a28667fef6258d4a10.png 分析部分:

1.通过字符串末尾的'\0' 来进行追加,追加至'\0'的后面!

2.源头里的'\0' 告诉我们什么时候停止!

3.目标空间里的'\0' 告诉我们从哪儿开始进行追加!

4.目标空间必须足够大,才能追加正确!!

5.目标空间必须可以修改!!

对字符串追加函数:strcat的模拟实现!!压轴部分!!

请看笔者的参考代码:

#include <stdio.h>
#include <string.h>
 
char* my_strcat(char* dest, const char* src)
{
	//找到目标空间中的\0
	char* cur = dest;
	while (*cur != '\0')
	{
		cur++;
	}
	//拷贝源头数据到\0之后的空间
	while (*cur++ = *src++)
	{
		;
	}
	return dest;
	//返回目标空间的起始位置
}
 
int main()
{
	char arr1[20] = "hello \0xxxxxxxxxxxx";
	char arr2[] = "wang";
	my_strcat(arr1, arr2);
	printf("%s\n", arr1);
	return 0;
}

在该段代码中:

1.最主要的还是在找到目标空间中的'\0'的位置,然后才能进行追加!

因此,第一步:必须先找到第一个'\0'的位置,然后按照strcpy字符串拷贝函数写法进行拷贝过去!!

61c5ce591bc643aaaa66c48c8f0ae2df.png 对于上述的代码,笔者就不再进行更多的讲解!毕竟里面除了找到'\0'的是个新接触到的知识,其他的都是在前面两个博客中已经详细的讲解了!若是各位老铁,有苦难,可以去参考前面的两篇博客来进行分析,也可以私聊笔者!!

代码的运行结果为:

c5ffedf34bbd4fb4930bfb1de5b13e41.png

上面讲解了strcat字符串追加函数的使用!那么问题也来了!

使用strcat字符串追加函数:能不能给自己追加????

答案是显而易见的:不可以,坚决不可以!!

不相信的读者,可以参考一下笔者代码:

#include <stdio.h>
#include <string.h>
 
int main()
{
	char arr1[200] = "hello ";
	strcat(arr1, arr1);
	printf("%s\n", arr1);
	return 0;
}

这个是一个死循环的代码!!也会越界访问!!!

85c968a207004017863aee24f91ff369.png 对于:详解字符串追加函数:strcat的使用及模拟实现!!笔者就讲到该部分就结束了!!读者若是有其他不懂得问题,可以私聊哟!!

详解字符串比较函数:strcmp函数及其模拟实现!!!

对于字符串比较函数:strcmp函数,想必大家也不会感觉陌生,毕竟在之前就有过接触!虽然很少使用,但是,见面了也能认出来!只不过不太怎么使用过罢了!!

话不多说,笔者下面进入正题,来带领大家回归今日的主题!

strcmp是字符串的比较函数,该比较多不是字符串的长度,而是比较的对应位置的ASCII码值的大小!

使用方法为:

int strcmp (const char* str1 , const char* str2)

对于返回类型为int ,或许不少老铁有着……疑问??为什么返回值会是int(整型)呢??

str1 < str2 : 返回一个小于0的数字:-1

str1 > str2  :返回一个大于0的数字: 1

str1 = str2  :返回0

对于上述不认同的读者,可以参考一下,笔者的代码:

#include <stdio.h>
#include <string.h>
 
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abq";
	int ret = strcmp(arr1, arr2);
	printf("%d\n", ret);
	return 0;
}

因为在ASCII码中’c'对应的值小于'q'所对应的值,所以打印的结果为-1

代码的运行结果为:

d9740aa993d54b58b9de14f98c3f686f.png 但是当arr1[],arr2[]更改数值以后,代码的运行结果也会随之发生改变,所以……嗯!所以返回值为:-1,1,0;没啥大问题!!

#include <stdio.h>
#include <string.h>
 
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abq";
	
	char arr3[] = "abcd";
	char arr4[] = "abc";
 
	char arr5[] = "abc";
	char arr6[] = "abc";
 
	int ret = strcmp(arr1, arr2);
	if (ret > 0)
	{
		printf("arr1>arr2\n");
	}
	else if (ret < 0)
	{
		printf("arr1<arr2\n");
	}
	else
	{
		printf("arr1=arr2\n");
	}
	return 0;
}

但是,对于:arr1[]={'a','b','c'},与arr2[]={'a','b','c'};该如何进行比较??

原因在于:'\0'的位置未知,不知道该怎么……嗯,因此,这就需要我们注意细节!!

下面来对strcmp函数来进行模拟实现!!请各位老铁仔细欣赏!!

#include <stdio.h>
#include <string.h>
#include <assert.h>
 
int my_strcmp(const char* s1, const char* s2)
{
	assert(s1 && s2);
	while (*s1 == *s2)
	{
		if (s1 == '\0')
		{
			return 0;
		}
		s1++;
		s2++;
	}
	if (*s1 > *s2)
	{
		return 1;
	}
	else
	{
		return -1;
	}
	
}
 
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abq";
	int ret = my_strcmp(arr1, arr2);
	if (ret > 0)
	{
		printf("arr1>arr2\n");
	}
	else if (ret < 0)
	{
		printf("arr1<arr2\n");
	}
	else
	{
		printf("arr1==arr2\n");
	}
	return 0;
}

对于该段代码的解析,毕竟没有什么很多的重要内容,想必各位老铁也都能看懂,缺少的仅仅是思路而已,笔者在此就不做更多的讲解!!

代码的运行结果为:

0bf9a19dfc33469a9b5791ffc9b9cf7b.png 本篇博客主要内容到此结束!!