当前位置:网站首页>(C语言)strlen、strcpy、strcat、strcmp、strstr函数的模拟实现
(C语言)strlen、strcpy、strcat、strcmp、strstr函数的模拟实现
2022-08-05 05:17:00 【Captain林】
本篇文章计划用简单的代码方式向大家介绍部分内存函数的模拟实现
主要目录如下
目录
1.模拟实现strlen-测字符串长度
//模拟实现strlen-测字符串长度
#include<stdio.h>
#include<assert.h>
size_t my_strlen(const char* str)
{
assert(str != NULL);//不用解引用,null要大写
int count = 0;
while (*str)
{
if (*str != "\0")
{
count++;
str++;
}
}
return count;
}
int main()
{
char arr[] = "abcdef";
int ret = my_strlen(arr);
printf("%d", ret);
return 0;
}
2.模拟实现strcpy - 复制字符串
//模拟实现strcpy - 复制字符串
//strcpy函数返回值可以实现链式访问
#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* arr1, const char* arr2)//返回的是地址,char*
{
/*assert(*arr1 && *arr2);*/
assert(arr1 && arr2);//不用解引用
char* ret = arr1;
while (*arr1++ = *arr2++)//因为这里涉及到改变指针所指向的值,因此要解引用;要用=!!!
{
;
}
return ret;//要返回地址,但不是arr1移动之后的地址
}
int main()
{
//char* arr1 = "abcdef";//要有数组的大小!
char arr1[20] = "abcdef";//要有足够空间
//char arr2[3] = "abc";
char* arr2 = "abc";//字符串应该用指针
printf("%s", my_strcpy(arr1, arr2));
return 0;
}
3.模拟实现strcat - 拷贝链接
//模拟实现strcat - 拷贝链接
#include<stdio.h>
#include<assert.h>
char* my_strcat(char* arr1, const char* arr2)
{
assert(arr1 && arr2);
char* ret = arr1;
//找到\0
while (*arr1)
{
arr1++;
}
//链接
while (*arr1++ = *arr2++)
{
;
}
return ret;
}
int main()
{
char arr1[20] = "abc";
char arr2[20] = "def";
//返回值是地址
printf("%s\n", my_strcat(arr1, arr2));
return 0;
}
4.模拟实现strcmp - 对比
//模拟实现strcmp - 对比
#include<stdio.h>
#include<assert.h>
int my_strcmp(const char* arr1, const char* arr2)
{
while (*arr1 == *arr2)//比对
{
//为0
if (*arr1 == '\0')
{
return 0;
}
arr1++;
arr2++;
}
//不相等
return (int)*arr1 - (int)*arr2;
}
int main()
{
char arr1[] = "abcd";
char arr2[] = "abcf";
int ret = my_strcmp(arr1, arr2);
if (ret > 0)
{
printf(">\n");
}
else if (ret = 0)
{
printf("=\n");
}
else
{
printf("<");
}
return 0;
}
5.模拟实现strstr - 寻找字符串子集
//模拟实现strstr - 寻找字符串子集
#include<stdio.h>
#include<assert.h>
char* my_strstr(const char* arr1, const char* arr2)
{
assert(arr1 && arr2);
const char* s1 = arr1;
const char* s2 = arr2;
char* cur = arr1;
while (*cur)
{
s1 = cur;
s2 = arr2;
while (*s1 && *s2 && (*s1 == *s2))
{
s1++;
s2++;
}
if (*s2 == '\0')//这里需要单引号,且不能放在循环中
{
return cur;
}
cur++;
}
return NULL;//s1已经到\0
}
int main()
{
char arr1[20] = "abcdef";
char arr2[20] = "bcd";
//字串?
char* ret = my_strstr(arr1, arr2);
if (NULL != ret)
{
printf("%s\n", ret);
}
else
{
printf("找不到子集");
}
return 0;
}
6.结语
看到这里,相信老铁们对如何应用这些内存函数已经有了基本的了解。我是计算机海洋的新进船长Captain_ldx,如果我的文章能对您有帮助的话,麻烦各位观众姥爷们点赞、收藏、关注,你们的每一次举手之劳都将化为船长的前进动力!
边栏推荐
猜你喜欢
LeetCode刷题之第530题
LeetCode刷题之第1024题
【论文精读】ROC和PR曲线的关系(The relationship between Precision-Recall and ROC curves)
八、请求处理之自定义类型参数绑定原理
深度学习系列(二)优化器 (Optimization)
【数据库和SQL学习笔记】9.(T-SQL语言)定义变量、高级查询、流程控制(条件、循环等)
CVPR2021 - Inception Convolution with Efficient Dilation Search
1008 数组元素循环右移问题 (20 分)
【数据库和SQL学习笔记】6.SELECT查询4:嵌套查询、对查询结果进行操作
【数据库和SQL学习笔记】7.SQL中的插入(INSERT)、删除(DELETE)、更新(UPDATE)
随机推荐
七、请求处理——Map、Model类型参数处理原理
LeetCode刷题之第86题
六、请求处理—获取请求参数系列注解是怎样工作的?
Redis设计与实现(第一部分):数据结构与对象
LeetCode刷题之第33题
一个小时教你如何掌握ts基础
CVPR 2022 | 70% memory savings, 2x faster training
基于STM32F407的WIFI通信(使用的是ESP8266模块)
Service
读论文-Cycle GAN
[Pytorch study notes] 9. How to evaluate the classification results of the classifier - using confusion matrix, F1-score, ROC curve, PR curve, etc. (taking Softmax binary classification as an example)
五、请求处理—Rest映射是怎样实现的?
【论文精读】R-CNN 之预测框回归(Bounding box regression)问题详述
【Pytorch学习笔记】8.训练类别不均衡数据时,如何使用WeightedRandomSampler(权重采样器)
【Pytorch学习笔记】9.分类器的分类结果如何评估——使用混淆矩阵、F1-score、ROC曲线、PR曲线等(以Softmax二分类为例)
CAN、CAN FD
【数据库和SQL学习笔记】3.数据操纵语言(DML)、SELECT查询初阶用法
基于STM32F4的FFT+测频率幅值相位差,波形显示,示波器,时域频域分析相关工程
TinyFlashDB:一种超轻量的可纠错的通用单片机flash存储方案
【shell编程】第二章:条件测试语句