🎖️1.函数介绍
📬1.1. strlen
🚩(1)字符串已 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ’\0’ 前面出现的字符个数(不包含 ‘\0’)
🚩(2) 参数指向的字符串必须要以 ‘\0’ 结束
🚩(3) 注意函数的返回值为 size_t ,是无符号的
🚩(4) 学会strlen函数的模拟实现
可以参考一下 cplusplus 中的资料👇
🔴(1)请看示例代码👇
#include<stdio.h> #include<string.h> int main() { int len1 = strlen("abcdef"); printf("%d\n", len1); char arr[] = "abc\0def"; int len2 = strlen(arr); printf("%d\n", len2); return 0; }
🔴(2)请看示例代码👇
int main() { char arr[3] = { 'a','b','c' }; int len = strlen(arr); printf("%d\n", len); return 0; }
🚨因为它会一直向后找,直到找到 ’\0’ 才停止,所以输出的是个随机值
🔴(3)请看示例代码输出的是什么呢👇
int main() { if (strlen("abc") - strlen("abcdef") > 0) { printf(">\n"); } else { printf("<\n"); } return 0; }
🚨一定要记住strlen函数的返回值为 size_t — 是无符号整型的
🔴(4)模拟实现strlen函数👇
1️⃣ 计数器👇
//计数器 #include<assert.h> int my_strlen(const char* str) { int count = 0; assert(str); while (*str != '\0') { count++; str++; } return count; } int main() { char arr[] = "hello"; int len = my_strlen(arr); printf("%d\n", len); return 0; }
2️⃣递归实现👇
//递归 //不能创建临时变量,求字符串长度 int my_strlen(const char* str) { if (*str != '\0') return 1 + my_strlen(str + 1); else return 0; } int main() { char arr[] = "hello"; int len = my_strlen(arr); printf("%d\n", len); return 0; }
3️⃣指针 - 指针👇
//指针 - 指针 #include<assert.h> int my_strlen(const char* str) { char* start = str; assert(str && start); while (*str) { str++; } return str - start; } int main() { char arr[] = "hello"; int len = my_strlen(arr); printf("%d\n", len); return 0; }
📬1.2. strcpy
🚩(1) 源字符串必须以 ‘\0’ 结束
🚩(2) 会将源字符串中的 ‘\0’ 拷贝到目标空间
🚩(3) 目标空间必须足够大,以确保能存放源字符串
🚩(4) 目标空间必须可变
🚩(5) 学会模拟实现 strcpy函数
可以参考一下 cplusplus 中的资料👇
🚩char * strcpy ( char * destination, const char * source );
🔴(1)请看示例代码👇
#include<stdio.h> #include<string.h> int main() { char arr1[] = "abcdef"; char arr2[20] = { 0 }; strcpy(arr2, arr1); printf("%s\n", arr2); return 0; }
int main() { char arr1[] = "abc\0def"; char arr2[20] = { 0 }; strcpy(arr2, arr1); printf("%s\n", arr2); return 0; }
🔴(3)目标空间必须足够大👇
//这是一个错误示范 - 目标空间必须足够大 int main() { char arr1[20] = "abcdefghi"; char arr2[3] = ""; strcpy(arr2, arr1); printf("%s\n", arr2); return 0; }
🔴(4)目标空间必须可以修改👇
//这也是一个错误示范 - 目标空间必须可以修改 int main() { char *p = "abcdefghi"; char arr2[20] = "hehe"; strcpy(p, arr2); printf("%s\n", p); return 0; }
🔴(5)模拟实现 strcpy函数👇
#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[] = "hehehe"; char arr2[20] = { 0 }; my_strcpy(arr2, arr1); printf("%s\n", arr2); return 0; }
📬1.3. strcat
🚩(1) 源字符串必须以 ‘\0’ 结束
🚩(2) 目标空间也必须有 ‘\0’
🚩(3) 目标空间必须足够大,能容纳下源字符串的内容
🚩(4) 目标空间必须可修改
🚩(5) 字符串给自己追加会如何?
可以参考一下 cplusplus 中的资料👇
🔴(1)请看示例代码👇
#include<string.h> int main() { char arr1[20] = "hello "; char arr2[] = "world"; //追加 strcat(arr1,arr2); printf("%s\n", arr1); return 0; }
🔴(2)模拟实现 strcat函数👇
#include<stdio.h> #include<string.h> #include<assert.h> char* my_strcat(char* dest, const char* src) { assert(dest && src); char* ret = dest; //找目标空间中的 \0 while (*dest != '\0') { dest++; } //拷贝 while(*dest++ = *src++) { ; } return ret; } int main() { char arr1[20] = "hello "; char arr2[] = "world"; //追加 my_strcat(arr1,arr2); printf("%s\n", arr1); return 0; }
🔴(3) 字符串给自己追加会如何?👇
char* my_strcat(char* dest, const char* src) { assert(dest && src); char* ret = dest; while (*dest != '\0') { dest++; } //拷贝 while(*dest++ = *src++) { ; } return ret; } int main() { char arr1[20] = "hello"; my_strcat(arr1, arr1); printf("%s\n", arr1); return 0; }
🚨会陷入死循环,根本停不下来‼️
🚨因为在第一轮拷贝中 ‘\0’就被赋值了’h‘,所以一直往后找再也找不到 ’\0‘了,陷入死循环
📬1.4. strcmp
🔴比较2个字符串的内容的时候,不能使用==,应该使用strcmp
🔴if (“abcdef” == “bbcdef”) 这里比较的是两个字符串首字母的地址,而不是字符串的内容
🚩(1) 比较2个字符串的内容的时候,不能使用==,应该使用strcmp
🚩(2) if (“abcdef” == “bbcdef”) 这里比较的是两个字符串首字母的地址,而不是字符串的内容
🚩(3) 比较的是对应位置上字符的 ASCII码值的大小
可以参考一下 cplusplus 中的资料👇
📍第一个字符串大于第二个字符串,则返回大于0的数字
📍第一个字符串大于第二个字符串,则返回0
📍第一个字符串大于第二个字符串,则返回小于0的数字
🔴(1)请看示例代码👇
#include<stdio.h> #include<string.h> int main() { //比较的是对应位置上字符的 ASCII码值的大小 char arr1[] = "abcdef"; char arr2[] = "abq"; int ret = strcmp(arr1, arr2); printf("%d\n", ret); return 0; }
int main() { char arr1[] = "abq"; char arr2[] = "abq"; int ret = strcmp(arr1, arr2); printf("%d\n", ret); return 0;
🔴(2)模拟实现 strcmp函数👇
#include<stdio.h> #include<string.h> #include<assert.h> int my_strcmp(const char* str1, const char* str2) { assert(str1 && str2); while (*str1 == *str2) { if (*str1 == '\0') return 0; str1++; str2++; } if (*str1 > *str2) return 1; else return -1; } int main() { char arr1[] = "abcdef"; char arr2[] = "abq"; int ret = my_strcmp(arr1, arr2); printf("%d\n", ret); return 0; }
📬1.5. strncpy
🔴长度不受限制的字符串函数:strcpy , strcat , strcmp
🔴长度受限制的字符串函数:strncpy , strncat , strncmp
🌰举个栗子👇
int main() { char arr1[] = "abcdef"; char arr2[5] = "yuio"; strncpy(arr1, arr2, 3); printf("%s\n", arr1); return 0; }
📬1.6. strncat
🌰举个栗子👇
int main() { char arr1[20] = "hello"; char arr2[] = "yuio"; strncat(arr1, arr2, 3); printf("%s\n", arr1); return 0; }
可以自己追加自己👆
📬1.7. strncmp
🌰举个栗子👇
int main() { char arr1[] = "abcdef"; char arr2[] = "abcq"; int ret = strncmp(arr1, arr2, 4); printf("%d\n", ret); return 0; }