内存函数详解

140 阅读4分钟

hello,大家好,今天的主人公是字符串函数。 第一位主角是:家喻户晓的strlen函数:

strlen:

返回类型及参数:size_t strlen ( const char * str ); 作用简介:求字符串的大小。 1.字符串已经 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包 含 '\0' )。//strlen函数返回的数/0之前字符的个数。 2.参数指向的字符串必须要以 '\0' 结束。 3.注意strlen的返回值为size_t,是无符号的( 易错 )。 下面我们对strlen函数进行模拟实现

#include<stdio.h>
#include <string.h>
int main()
{
	if ((int)strlen("abc") -(int)strlen("abcdef")>0 )
	{
		printf("大于\n");
	}
	else
	{
		printf("小于等于\n");
	}
	return 0;
}
#include<stdio.h>
#include<assert.h>
计数器
size_t my_strlen(char* p)
{
	assert(p);
	int count = 0;
	while (*p != '\0')
	{
		p++;
		count++;
	}
	return count;
}
指针减指针
size_t my_strlen(char* p)
{
	assert(p);
	char* s = NULL;
	s = p;
	while (*s != '\0')
	{
		s++;
	}
	return s - p;
}
递归方法
size_t my_strlen(char* s)
{
	if (*s == '\0')
	{
		return 0;
	}
	else
	{
		return 1 + my_strlen(s+1);
	}
}
int main()
{
	size_t sz = my_strlen("abc");
	printf("%d", sz);
	return 0;
}

运行结果: image.png

strcpy:

返回类型及参数:char * strcpy ( char * destination, const char * source ); 作用简介:将source指向的字符串拷贝到des指向的空间中。 1.源字符串必须以 '\0' 结束。 2.会将源字符串中的 '\0' 拷贝到目标空间。 3.目标空间必须足够大,以确保能存放源字符串。 4.目标空间必须可变。 下面是strcpy模拟实现:

#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* des, const char* sou)
{
	assert(des && sou);//判断des和sou是否为空指针
	char* p1 = des;
	while (*des++ = *sou++)//将*sou赋值给*des,然后加加指向下一个元素
	{
		;
	}
	return p1;//返回目标地址
}
int main()
{
	char arr[10] = "abch";
	char arr2[10] = "ertyuui";
	my_strcpy(arr, arr2);
	printf("%s", arr);
	return 0;
}

strcat:

作用简介:将source指向的C字符串复制到destination指向的数组中,包括结束的null字符(并在该点停止) 返回类型和参数**:char * strcat ( char * destination, const char * source );** 1.源字符串必须以 '\0' 结束。 2.目标空间必须有足够的大,能容纳下源字符串的内容。 3.目标空间必须可修改。 strcat模拟实现:

char* my_strcat(char* dest, char* src)
{
	char* p = dest;//记录目标地址
	assert(dest && src);//判断dest和src是否为空指针
	//第一步先找到arr的/0的位置
	while (*dest)
	{
		dest++;
	}
	//第二步将src赋值给dest指向的空间
	while (*dest++ = *src++)
	{
		;
	}
}
int main()
{
	char arr[30] = "abcdefgh";
	char arr2[10] = "hello";
	strcat(arr, arr2);
	printf("%s", arr);
	/*int n = my_strcat(arr, arr2);
	printf("%s", n);*/
	return 0;
}

运行结果: image.png

strcmp:

返回类型及参数:int strcmp ( const char * str1, const char * str2 ); **作用简介:将源字符串的副本追加到目标字符串。**destination中的结束null字符被source的第一个字符覆盖,并且在destination中由两者串联形成的新字符串的末尾包含一个空字符。 1.第一个字符串大于第二个字符串,则返回大于0的数字 第一个字符串等于第二个字符串,则返回0 第一个字符串小于第二个字符串,则返回小于0的数字 strcmp模拟实现:

int my_strcmp(char* p1, char* p2)
{
	assert(p1 && p2);
	while (*p1 == *p2)//当*p1等于*p2时p1++;p2++;
	{
		p1++;
		p2++;
	}
	if (*p1 < *p2)
	{
		return -1;
	}
	else if (*p1 > *p2)
	{
		return 1;
	}
	else
	{
		return 0;
	}
}
int main()
{
	char arr1[10] = "abcdefg";
	char arr2[10] = "rtythl";
	int n = my_strcmp(arr1, arr2);
	printf("%d", n);
	return 0;
}

运行结果: image.png

strstr:

返回类型:const char * strstr ( const char * str1, const char * str2 ); 作用简介:返回指向str1中str2第一次出现的指针,如果str2不是str1的一部分,则返回空指针。 strstr模拟实现:

char* my_strstr(char* str1, char* str2)
{
	char* cp = str1;
	char* s1 = cp;
	char* s2 = str2;

	if (*str2 == '\0')
		return str1;
	while (*cp)
	{
		//开始匹配
		s1 = cp;
		s2 = str2;
		while (*s1 && *s2 && *s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
			return cp;

		cp++;
	}

	return NULL;
}
int main()
{
	char arr1[] = "abbbcdef";
	char arr2[] = "bbc";

	char* ret = my_strstr(arr1, arr2);
	if (ret != NULL)
		printf("%s\n", ret);
	else
		printf("找不到\n");

	return 0;
}

运行结果: image.png

strtok:

返回类型:char * strtok ( char * str, const char * sep ); 作用简介:1.strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注: strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容 并且可修改。) 2.strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串 中的位置。 3.strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标 记。 4.如果字符串中不存在更多的标记,则返回 NULL 指针。 代码演示:

#include<string.h>
int main()
{
	char arr[] = "qwertyui@yeah.jiangzhe";
	char set[] = "@.";
	char arr2[30];
	strcpy(arr2, arr);
	/*char* ret = strtok(arr, set);
	printf("%s\n", ret);

	ret = strtok(NULL, set);
	printf("%s\n", ret);

	ret = strtok(NULL, set);
	printf("%s\n", ret);*/
	//优化版
	char* ret = NULL;
	for ((ret = strtok(arr2, set)); ret != NULL;ret = strtok(NULL,set))
	{
		printf("%s\n", ret);
	}

	return 0;
}

运行结果: image.png