当前位置: 首页 > news >正文

字符函数和字符串函数【上篇】

文章目录

  • 🎖️1.函数介绍
    • 📬1.1. strlen
    • 📬1.2. strcpy
    • 📬1.3. strcat
    • 📬1.4. strcmp
    • 📬1.5. strncpy
    • 📬1.6. strncat
    • 📬1.7. strncmp

在这里插入图片描述

🎖️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);elsereturn 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;//找目标空间中的 \0while (*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;elsereturn -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;
}

在这里插入图片描述

总结🥰
以上就是 字符函数和字符串函数【上篇】 的内容啦🥳🥳🥳🥳
本文章所在【C语言知识篇】专栏,感兴趣的烙铁可以订阅本专栏哦🥳🥳🥳
欲知后事如何,请听下篇分解喽😘😘😘
希望我们可以做一个用心的人💕💕💕
小的会继续学习,继续努力带来更好的作品😊😊😊
创作写文不易,还多请各位大佬uu们多多支持哦🥰🥰🥰

请添加图片描述

http://www.lryc.cn/news/40807.html

相关文章:

  • list的模拟实现(模仿STL)
  • 05-STM32F1 - 串行通信SPI
  • 【Pytorch】Tensor的分块、变形、排序、极值与in-place操作
  • 数组栈的实现
  • *p++,*(p++),*++p,(*p)++区别?
  • 又一个线上偶发问题-系统短暂无法获取到Redis连接
  • [ 系统安全篇 ] 拉黑IP - 火绒安全软件设置IP黑名单 windows使用系统防火墙功能设置IP黑名单
  • MongoDB【部署 01】mongodb最新版本6.0.5安装部署配置使用及mongodb-shell1.8.0安装使用(云盘分享安装文件)
  • 算法竞赛必考算法——动态规划(01背包和完全背包)
  • 基于深度学习的农作物叶片病害检测系统(UI界面+YOLOv5+训练数据集)
  • QT入门Item Views之QListView
  • GEE:计算1990-2021年的指数最大值和最小值,并根据最大最小值对每一副影像归一化
  • LeetCode KMP 算法
  • 全面剖析OpenAI发布的GPT-4比其他GPT模型强在哪里
  • leetcode——26. 删除有序数组中的重复项
  • 基于springboot垃圾分类网站设计实现【毕业论文、源码】
  • 计算机组成原理实验一(完整)
  • 【SSM】MyBatis(一.基础)
  • LInux指令之文件目录类
  • 【c++】:STL中vector的模拟使用及模拟实现
  • C++ STL:vector的使用方法及模拟实现
  • naive UI 的upload组件自定义手动上传图片的base64位
  • 信创办公–基于WPS的PPT最佳实践系列(表格和图标常用动画)
  • Spring Bean实例化和初始化的过程
  • WorkTool企微机器人接入智能问答
  • C导入正则库问题
  • 尚融宝05-Node.js入门
  • 「SAP ABAP」OPEN SQL(八)【WHERE语句大全】
  • Ribbon负载均衡的原理(源码分析)
  • 用sql计算两个经纬度坐标距离(米数互转)