详解字符串追加函数:strcat的使用及模拟实现!!!
对于字符串,有着千奇百怪的使用方法!在前篇文章,笔者讲解了:字符串统计:字符串统计:strlen函数的讲解,及其模拟实现!!紧接着还有:字符串拷贝函数:strcpy的详解及模拟实现!!!笔者一脸忧愁!!太多了,其实我也记不清楚!!只能大概,也许,可能……嗯
话不多说,我们来进入今天的正题部分!!
笔者查阅资料可得:对于strcat函数的使用方法为:
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;
}
对于上述代码的运行结果也是显而易见的:
但是,在“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;
}
对代码进行调试:
调试结束时的运行结果为:
结合调试的结果,我们可以看出:‘\0'也进行了追加!!
代码的运行结果为:
分析部分:
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字符串拷贝函数写法进行拷贝过去!!
对于上述的代码,笔者就不再进行更多的讲解!毕竟里面除了找到'\0'的是个新接触到的知识,其他的都是在前面两个博客中已经详细的讲解了!若是各位老铁,有苦难,可以去参考前面的两篇博客来进行分析,也可以私聊笔者!!
代码的运行结果为:
上面讲解了strcat字符串追加函数的使用!那么问题也来了!
使用strcat字符串追加函数:能不能给自己追加????
答案是显而易见的:不可以,坚决不可以!!
不相信的读者,可以参考一下笔者代码:
#include <stdio.h>
#include <string.h>
int main()
{
char arr1[200] = "hello ";
strcat(arr1, arr1);
printf("%s\n", arr1);
return 0;
}
这个是一个死循环的代码!!也会越界访问!!!
对于:详解字符串追加函数: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
代码的运行结果为:
但是当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;
}
对于该段代码的解析,毕竟没有什么很多的重要内容,想必各位老铁也都能看懂,缺少的仅仅是思路而已,笔者在此就不做更多的讲解!!
代码的运行结果为:
本篇博客主要内容到此结束!!