进阶C语言-字符函数和字符串函数


字符函数和字符串函数

  • 🎈1.函数介绍
    • 🔎1.1strlen函数
      • 🔭1.1.1strlen函数的模拟实现
        • 📖1.计数器法
        • 📖2.递归法
        • 📖3.指针-指针
    • 🔎1.2strcpy函数
      • 🔭1.2.1strcpy函数的模拟实现
    • 🔎1.3strcat函数
      • 🔭1.3.1strcat函数的模拟实现
    • 🔎1.4strcmp函数
      • 🔭1.4.1strcmp函数的模拟实现
    • 🔎1.5strncpy函数
    • 🔎1.6strncat函数
    • 🔎1.7strncmp函数
    • 🔎1.8strstr函数
    • 🔎1.9strtok函数
    • 🔎1.10strerror函数

🎈1.函数介绍

🔎1.1strlen函数


✅注意事项:

  • 字符串以'\0'作为结束标志,strlen函数返回的是在字符串中'\0'前面出现的字符个数(不包括'\0'
  • 参数指向的字符串必须以'\0'结束
  • 注意函数的返回值是size_t,是无符号的
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
//库函数
//strlen用来求字符串长度
//本质上是统计字符串中\0之前的字符个数
int main()
{
	const char* str = "abcdef";
	size_t len1 = strlen(str);
	size_t len2 = strlen("abcdef");
	size_t len3 = strlen("abc\0edf");
	printf("%d\n", len1);
	printf("%d\n", len2);
	printf("%d\n", len3);
	return 0;
}

✅运行示例:

🔭1.1.1strlen函数的模拟实现

📖1.计数器法

assert函数作用是断言,断言是一种除错机制,用于验证代码是否符合编码人员的预期。编码人员在开发期间应该对函数的参数、代码中间执行结果合理地使用断言机制,确保程序的缺陷尽量在测试阶段被发现。使用assert函数时需要添加头文件#include <assert.h>.

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* str)//字符串是放在常量字符串中,不能被改变,所以这里最好用用const修饰一下
{
	assert(str != NULL);//p如果接收过来的是空指针,那么这里运行会崩溃的,所以这里用assert函数断言一下
	int count = 0;//计数
	while (*str != '\0')
	{
		count++;//当它的字符不等于'\0'时,计数加一
		str++;//再往下一个字符找
	}
	return count;
}
int main()
{
	const char* str = "abcdef";
	printf("%d", my_strlen(str));
	return 0;
}

✅运行示例:

📖2.递归法
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* str)
{
	assert(str != NULL);
	if (*str != '\0')
	{
		return 1 + my_strlen(str + 1);
	}
	else
		return 0;
}
int main()
{
	const char* str = "abcdef";
	printf("%d", my_strlen(str));
	return 0;
}

✅运行示例:

📖3.指针-指针
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* str)
{
	assert(str != NULL);
	const char* start = str;//定义一个指针放字符串首字符的地址,因为*str接收的字符串为常量字符串,所以这里最好也用const修饰一下
	while (*str != '\0')
	{
		str++;
	}
	return str - start;
}
int main()
{
	const char* str = "abcdef";
	printf("%d", my_strlen(str));
	return 0;
}

✅运行示例:

🔎1.2strcpy函数

  • 源字符串必须以'\0'结束
  • 会将源字符串中的'\0'拷贝到目标空间
  • 目标空间必须足够大,以保证能存放源字符串
  • 目标空间必须可变
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[10] = { 0 };
	char arr2[10] = "Hello";
	printf("%s\n", strcpy(arr1, arr2));
	return 0;
}

✅运行示例:


注:strcpy函数会将源字符串中的'\0'拷贝到目标空间。

🔭1.2.1strcpy函数的模拟实现

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <assert.h>
char* my_strcpy(char* dest, const char* src)
{
	char *ret = dest;
	assert(dest && src);
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}
int main()
{
	char arr1[20] = { 0 };
	char arr2[] = "Hello";
	printf("%s\n",my_strcpy(arr1, arr2));
	return 0;
}

✅运行示例:

🔎1.3strcat函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[20] = "Hello";
	char arr2[] = "World";
	printf("%s\n", strcat(arr1, arr2));
	return 0;
}

✅运行示例:

🔭1.3.1strcat函数的模拟实现

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
char* my_strcat(char* dest, char* src)
{
	char* ret = dest;
	while (*dest != '\0')
	{
		dest++;
	}
	while (*dest++ = *src++)
	{
		;
	}
	return ret;
}
int main()
{
	char arr1[20] = "Hello";
	char arr2[] = "World";
	printf("%s\n", my_strcat(arr1, arr2));
	return 0;
}

✅运行示例:

注意:

  • 目标空间必须足够大,还需要可以修改。
  • 目标空间必须得有'\0'(保证找到目标空间的末尾)。
  • 源字符串中也得有'\0',在拷贝时将源字符串中的'\0'也要拷贝过去。

🔎1.4strcmp函数

  • 第一个字符串大于第二个字符串,返回大于0的数字。
  • 第一个字符串小于第二个字符串,返回小于0的数字。
  • 第一个字符串等于第二个字符串,返回0。
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[] = "Hello";
	char arr2[] = "World";
	printf("%d\n", strcmp(arr1, arr2));
	return 0;
}

✅运行示例:

🔭1.4.1strcmp函数的模拟实现

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int my_strcmp(const char* str1, const char* str2)
{
	while (*str1 == *str2)
	{
		str1++;
		str2++;
	}
	if (*str1 > *str2)
		return 1;
	else
		return -1;
}
int main()
{
	char arr1[] = "Hello";
	char arr2[] = "World";
	printf("%d\n", my_strcmp(arr1, arr2));
	return 0;
}

✅运行示例:

🔎1.5strncpy函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[20] = { 0 };
	char arr2[] = "World";
	printf("%s\n", strncpy(arr1, arr2,3));
	return 0;
}

✅运行示例:

🔎1.6strncat函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[20] = "hi";
	char arr2[] = "World";
	printf("%s\n", strncat(arr1, arr2, 3));
	return 0;
}

✅运行示例:

🔎1.7strncmp函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[20] = "Worle";
	char arr2[] = "World";
	printf("%d\n", strncmp(arr1, arr2, 3));
	return 0;
}

✅运行示例:

🔎1.8strstr函数

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[] = "abcdefghi";
	char arr2[] = "op";
	char* ret = strstr(arr1, arr2);
	if (ret == NULL)
	{
		printf("找不到!\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

✅运行示例:

🔎1.9strtok函数

  • delimiters参数是个字符串,定义了用作分隔符的字符集合。
  • 第一个参数指定一个字符串,它包含了0个或多个由delimiters字符串中一个或者多个分隔符分割的标记。
  • strtok函数找到str中的下一个标记,并将其用'\0'结尾,返回一个指向这个标记的指针。
  • strtok函数的第一个参数不为NULL,函数找到str中第一个标记,strtok函数将保存它在字符串中的位置。
  • strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
  • 如果字符串不存在更多的标记,则返回NULL指针。
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	char arr[] = "angle@qq.com";
	char buf[200] = { 0 };
	strcpy(buf, arr);
	const char* p = "@.";
	char* s = NULL;
	for (s = strtok(buf, p); s != NULL; s = strtok(NULL,p))
	{
		printf("%s\n", s);
	}
	return 0;
}

✅运行示例:

🔎1.10strerror函数

strerror是将错误码翻译成错误信息,返回错误信息的字符串的起始地址。

C语言中使用库函数的时候,如果发生错误,就会将错误码放在errno的变量中,errno是一个全局的变量,可以直接使用。

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <string.h>
int main()
{
	for (int i = 0; i < 10; i++)
	{
		printf("%d:%s\n", i, strerror(i));
	}
	return 0;
}


注: perror=printf+strerror.

好啦,关于字符串函数的知识到这里就先结束啦,后期会继续更新学习C语言的相关知识,欢迎大家持续关注、点赞和评论!❤️❤️❤️

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
青葱年少的头像青葱年少普通用户
上一篇 2023年12月11日
下一篇 2023年12月11日

相关推荐