strlen、strcpy、strcat、strcmp小解及模拟实现

发布于:2022-12-06 ⋅ 阅读:(313) ⋅ 点赞:(0)

strlen

无符号整形的字符串长度统计,在'\0'处终止,并且不会将‘\0’放入长度之中。

这里要注意,字符串中必须要出现‘\0’,因为没有'\0'意味着没有终止,会一直往后面进行计算,这样就失去了这个库函数的意义

由于strlen是无符号整型,所以意味着没有负数这一类别,因为字符串的长度只有0或者更长,而不会有负的字符串长度,所以是不会出现负数;

这一点要十分小心,因为在一些代码之很容易出现一些问题,如下

#include<stdio.h>
int main()
{
    char ch1[] = "abcde";
    char ch2[] = "abc";
    if(strlen(ch2)-strlen(ch1)>0)
    {
        printf("ch2>ch1\n");
    }
    else
    {
        printf("ch1>ch2\n");
    }
    return 0;
}

请问,这里的代码结果会是什么?

答案如下

 

 是不是感觉很奇怪,但是你要是能理解前面strlen是无符号整形就可以理解了,

正常来说strlen(ch1)结果是5,而strlen(ch2)是3,5-3=-2,怎么看也不能ch2>ch1,但是strlen的返回类型是size_t,即无符号整形,,而无符号是什么意思,就是没有正负之分,所以-2这个数字是不会出现的,前面的符号会被编译器抓换成别的数字,即结果是恒不小于零的,所以就会出现这个情况!

而如果你这样一改

int main()
{
    char ch1[] = "abcde";
    char ch2[] = "abc";
    int a = strlen(ch2) - strlen(ch1);
    if (a > 0)
    {
        printf("ch2>ch1\n");
    }
    else
    {
        printf("ch1>ch2\n");
    }
    return 0;
}

结果会是什么?

 因为我用int a将他定义为有符号整形,有符号整型是有正负之分的,所以就会是这个样子!

下面是模拟实现,strlen就是只要不碰见'\0',就会一直往后面计算,所以就很好理解了

 

size_t my_strlen(const char* arr2)
{
	assert(arr2);//判断是否为空指针,若为空就不向下进行
	const char* start = arr2;
	const char* end = arr2;
	while (*end!='\0')
	{
		end++;
	}
	return end-start;//两个地址相减,结果是两者之间的元素个数
}
int main()
{
	char arr[] = "abcdef";
	int len = my_strlen(arr);
	printf("%d\n", len);
	return 0;
}

 strcpy

函数的作用:将源头的字符拷贝到目的地。

要求:两者都必须要有'\0',源头要有是因为知道是拷贝的截至地,而目的地有是为了明白从哪里拷贝;目的地的空间要足够大,能够完全的将你想要的源头的数据拷贝到目的地;目的地的空间内容要可以修改。

int main()
{
	char arr[10] = { 0 };
	char arr2[] = "abcde";
	strcpy(arr, arr2);
	printf("%s\n", arr);
	return 0;
}

 结果

 那么会不会将arr2中的\0拷贝进去呢?

 那么要是在”abcde“中加一个‘\0’,还会都拷贝进去吗?

 说明只会将第一个\0之前的字符拷贝进去

模拟实现strcpy

strcpy是将源头的第一个\0之前的字符逐一拷贝到目的地,遇到\0停止,要求同上,所以

char* my_strcpy(char* str, const char* str2)
{
	assert(str);//判断空指针
	assert(str2);//同上
	char* ret = str;//定义一个源头方便后面返回
	while (*str++ = *str2++)//将str2赋值给str1,然后分别++;直到遇见\0后停止
	{
		;
	}
	return ret;
}

int main()
{
	char ch[20] = "abc";
	char arr[] = "hello csnd";
	printf("%s\n", my_strcpy(ch, arr));//链式访问
	return 0;
}

strcat

 作用:将源头的字符追加到目的地

要求:两者都要有\0,源头为了明白截至地址,目的地明白从哪里开始追加;目的地要求必须可以修改;目的地要足够大

int main()
{
	char arr1[20] = "hello ";
	char arr2[] = "word!";
	strcat(arr1, arr2);
	printf("%s\n", arr1);
	return 0;
}

结果

 若是中间有\0会发生什么?

假如没有\0会发生什么可怕的事情?

 所以源头必须要有\0;

 strcmp

 

 作用:比较两个字符串对应位置字符的ASCII码大小。

第一个字符串大于第二个字符串返回大于0的值。

第一个字符串等于第二个字符串返回等于0的值。

第一个字符串小于第二个字符串返回小于0的值。

int main()
{
	char arr1[] = "abcd";
	char arr2[] = "abq";
	printf("%d\n", strcmp(arr1, arr2));
	return 0;
}

结果

 c的ASCII码值小于q,返回小于0的值


网站公告

今日签到

点亮在社区的每一天
去签到