【C语言】【字符串函数的模拟实现】strcpy,strcat,strcmp,strncpy,strncat,strstr

本文主要是介绍【C语言】【字符串函数的模拟实现】strcpy,strcat,strcmp,strncpy,strncat,strstr,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.strcpy

char* strcpy(char*destination,const char* source)
  • 源字符串必须以’\0’结尾
  • 会将原字符串中的‘\0’拷贝到目标字符串中
  • 目标空间必须足够大,能放得下源字符串

模拟实现:

char *my_strcpy(char* des,const char *sour)
{char* ret=des;assert(des);assert(sour);while(*des++=*sour++){;}return ret;

当sour走到’\0’的时候,跳出循环,完成拷贝

2.strcat

在目标字符串的末尾追加源字符串

  • 目标字符串和源字符串都必须以’\0’结束
  • 目标空间必须足够大

模拟实现

char* my_strcat(char* des,const char* source)
{assert(des);assert(source);char* ret=des;while(*des){des++;}while((*des++=*source++)){;}return ret;

3.strcmp

比较两个字符串的大小,通过两个字符串对应位置上字符ACLL码值的大小比较
如果两者第一个字符的ACLL码值相等,则继续比较第二个,依次往后比较
如果有一个字符串走到’\0’ 那么就用0 和另一个字符串中对应位置元素的ACLL码值比较

int strcmp(const char*str1,const char* str2)
  • 第一个字符串大于第二个 ->返回大于0的值
  • 小于–>返回小于0的值
  • 等于—>返回0

模拟实现

int my_strcmp(const char* str1,const char* str2)
{assert(str1);assert(str2);while(*str1==*str2){if(*str1=='\0')return 0;str1++;str2++;}return *str1-*str2;

4.strncpy

char* strnpy(char* des,const char* source,size_t num);

从字符串source中拷贝num个字符到目标字符串
如果源字符串中的字符数不足num,则在源字符串后面补0直到num个

5.strncat的使用

把指定个数的字符追加到一个字符串后面

#include<stdio.h>
#include<string.h>
int main()
{char des[20];char source[20];strcpy(des, "To be ");strcpy(source, "or not to be");strncat(des, source, 6);printf("%s", des);
}

在这里插入图片描述

在这里插入图片描述

6.strstr

作用是从一个字符串中查找指定字符串,返回所要查找的字符串首字符的地址

char* strstr(const char*,const char*);

使用举例:

#include <stdio.h>
#include <string.h>
int main()
{char str[] = "This is a simple string";char* pch;pch = strstr(str, "simple");strncpy(pch, "sample",6);printf("%s\n", str);return 0;
}

在这里插入图片描述

注意: 这里用strncpy,而不用strcpy,是因为strncpy可以复制指定个数的字符,可以用个数控制’\0’的复制,如果不想复制’\0’,上述个数就为6,若要复制’\0’,上述个数就为7。但是strcpy就一定会在末尾加上’\0’
在这里插入图片描述

模拟实现:

char* my_strstr(const char* str1, const char* str2)
{char* cp = (char*)str1;char* s1;char* s2 = (char*)str2;if (!*str2){return cp;}while (*cp){s1 = cp;s2 = (char*)str2;while (*s1 && *s2 && !(*s1 - *s2)){s1++;s2++;}if (!*s2)return cp;cp++;}return NULL;
}

这篇关于【C语言】【字符串函数的模拟实现】strcpy,strcat,strcmp,strncpy,strncat,strstr的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445270

相关文章

R语言中的正则表达式深度解析

《R语言中的正则表达式深度解析》正则表达式即使用一个字符串来描述、匹配一系列某个语法规则的字符串,通过特定的字母、数字及特殊符号的灵活组合即可完成对任意字符串的匹配,:本文主要介绍R语言中正则表达... 目录前言一、正则表达式的基本概念二、正则表达式的特殊符号三、R语言中正则表达式的应用实例实例一:查找匹配

Go语言结构体标签(Tag)的使用小结

《Go语言结构体标签(Tag)的使用小结》结构体标签Tag是Go语言中附加在结构体字段后的元数据字符串,用于提供额外的属性信息,这些信息可以通过反射在运行时读取和解析,下面就来详细的介绍一下Tag的使... 目录什么是结构体标签?基本语法常见的标签用途1.jsON 序列化/反序列化(最常用)2.数据库操作(

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

Python字符串处理方法超全攻略

《Python字符串处理方法超全攻略》字符串可以看作多个字符的按照先后顺序组合,相当于就是序列结构,意味着可以对它进行遍历、切片,:本文主要介绍Python字符串处理方法的相关资料,文中通过代码介... 目录一、基础知识:字符串的“不可变”特性与创建方式二、常用操作:80%场景的“万能工具箱”三、格式化方法

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoo WebFlux+MongoDB实现非阻塞API过程

《SpringBooWebFlux+MongoDB实现非阻塞API过程》本文介绍了如何使用SpringBootWebFlux和MongoDB实现非阻塞API,通过响应式编程提高系统的吞吐量和响应性能... 目录一、引言二、响应式编程基础2.1 响应式编程概念2.2 响应式编程的优势2.3 响应式编程相关技术

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb