C语言详细讲解常用字符串处理函数
目录
- 一、strlen()
- 1. 函数原型:
- 2. 手动实现:
- 二、strcat()
- 1. 函数原型:
- 2. 手动实现:
- 三、strcpy()
- 1. 函数原型:
- 2. 手动实现:
- 四、strcmp()
- 1. 函数原型:
- 2. 手动实现:
- 五、memset()
- 1. 函数原型:
- 2. 手动实现:
一、strlen()
1. 函数原型:
size_t strlen(const char *str)参数str: 要计算的字符串的长度
返回值: 返回字符串 str 的长度,直到遇到结束字符'\0',但不包括结束字符。
size_t 是一个无符号整数类型。
2. 手动实现:
源代码:
#include #include size_t my_strlen(const char *str){size_t len = 0; while (*str++ != '\0') {len++; }return len; }int main(){char *p = "hello world"; int len_1 = 0, len_2 = 0; len_1 = my_strlen(p); len_2 = strlen(p); printf("len_1 = %d, len_2 = %d\n", len_1, len_2); return 0; }
运行结果:
len_1 = 11, len_2 = 11
二、strcat() 1. 函数原型:
char *strcat(char *dest, const char *src)参数1: 目标字符串,该空间需要足够容纳后续追加的字符串。
参数2: 要追加的字符串。
返回值: 返回指向目标字符串的指针。
2. 手动实现:
源代码:
#include #include char *my_strcat(char *dest, const char *src){while (*dest != '\0') {dest++; }while (*src != '\0') {*dest++ = *src++; }*dest = '\0'; return dest; }int main(){char p1[20] = "hello "; char p2[20] = "hello "; char *q = "world"; my_strcat(p1, q); strcat(p2, q); printf("p1 = %s, p2 = %s\n", p1, p2); return 0; }
运行结果:
p1 = hello world, p2 = hello world
三、strcpy() 1. 函数原型:
char *strcpy(char *dest, const char *src)参数1: 要存储的目标字符串。
参数2: 要复制的字符串。
返回值: 返回指向目标字符串的指针。
2. 手动实现:
源代码:
#include #include char *my_strcpy(char *dest, const char *src){while (*src != '\0') {*dest++ = *src++; }*dest = '\0'; return dest; }int main(){char p1[20] = {'\0'}; char p2[20] = {'\0'}; char *q = "hello world"; my_strcpy(p1, q); strcpy(p2, q); printf("p1 = %s, p2 = %s\n", p1, p2); return 0; }
运行结果:
p1 = hello world, p2 = hello world
四、strcmp() 1. 函数原型:
int strcmp(const char *str1, const char *str2)参数1: 要比较的第一个字符串
参数2: 要比较的第二个字符串
返回值:
如果返回值 < 0,则表示 str1 小于 str2。
如果返回值 > 0,则表示 str1 大于 str2。
如果返回值 = 0,则表示 str1 等于 str2。
2. 手动实现:
源代码:
#include #include int my_strcmp(const char *str1, const char *str2){int ret = 0; while ((*str1 != '\0') && (*str1 == *str2)) {str1++; str2++; }ret = *str1 - *str2; return ret; }int main(){char p1[20] = {"hello world"}; char p2[20] = {"hello aorld"}; int ret_1, ret_2; ret_1 = my_strcmp(p2, p1); ret_2 = strcmp(p2, p1); printf("ret_1 = %d, ret_2 = %d\n", ret_1, ret_2); return 0; }
运行结果:
ret_1 = -22, ret_2 = -22
五、memset() 1. 函数原型:
void *memset(void *str, int c, size_t n)参数1: 要设置的内存块
参数2: 要填充的值,在填充内存块时是使用该值的无符号字符形式。
参数3: 填充的字符个数。
返回值: 返回指向str的指针。
2. 手动实现:
源代码:
#include #include void *my_memset(void *str, int c, size_t n){if (str == NULL) return NULL; char *pstr = (char*)str; while (n-- > 0) {*pstr++ = c ; }return str; }int main(){char p1[20] = {"hello world"}; char p2[20] = {"hello world"}; my_memset(p1, '*', 5); memset(p2, '*', 5); printf("p1 = %s, p2 = %s\n", p1, p2); return 0; }
运行结果:
p1 = ***** world, p2 = ***** world【C语言详细讲解常用字符串处理函数】到此这篇关于C语言详细讲解常用字符串处理函数的文章就介绍到这了,更多相关C语言字符串函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- C语言|windows系统c语言编译器安装
- 小程序微信支付c语言,微信小程序 - 支付(后端代码实现)
- java springboot vue实验室设备管理系统源码+论文1稿+代码讲解视频+安装视频+保远程安装配置
- Go 语言使用 MySQL 的常见故障分析和应对方法
- 给大家安利一款我开发的VSCode多语言插件
- JavaScript|JavaScript 语言入门
- 程序员|大牛深入讲解!Android面试中常问的MMAP到底是啥东东(再不刷题就晚了!)
- C语言|基于单链表的图书管理系统(C语言)
- 数据结构|图书管理系统 C语言链表实现 学校大作业功能齐全(书籍信息以及用户信息保存在附带的txt文件中)
- python设计一个图书管理的简单程序用单链表_轻松学做C语言课程设计(图书管理系统-链表实现...)