字符函数和字符串函数
- 🎈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语言的相关知识,欢迎大家持续关注、点赞和评论!❤️❤️❤️
文章出处登录后可见!
已经登录?立即刷新