部分库函数及其模拟

 前言:当我们学习c/c++库函数的时候,我们可以用网站

cplusplus.com - The C++ Resources Network

来进行查阅,学习。 

目录

库函数:

1.字符串函数

1.1求字符串长度

strlen

1.2长度不受限制的字符串函数

1.2.1strcpy

1.2.2strcat

1.2.3strcmp

1.3长度受限制的字符串函数介绍

1.3.1strncpy

1.3.2strncat

1.3.3strncmp

1.4字符串查找

1.4.1strstr

1.4.2strtok

1.5.错误信息报告

strerror

2.字符函数

1.字符分类函数

2.字符转换函数

3.内存函数


库函数:

1.字符串函数

字符串函数一般要用到头文件:<string.h> 

1.1求字符串长度

strlen

size_t strlen ( const char * str );

1.首先,字符串是以\0来结尾的,strlen返回的是字符串中" \0 "之前的元素个数,不包括 " \0 "

2.参数指向的字符必须以" \0 "来结尾

3.注意函数的返回值为size_t,是无符号的

使用

函数模拟:

1.计数器:

int my_strlen(char* str)
{int count = 0;while (*str){count++;str++;}return count;
}

2.不能使用计数器

int my_strlen(char* str)
{if (*str == '\0')return 0;else{return 1 + my_strlen(str + 1);}
}

3.指针

int my_strlen(char* str)
{char* p = str;while (*p != '\0'){p++;}return p - str;}

1.2长度不受限制的字符串函数

1.2.1strcpy
char * strcpy ( char * destination, const char * source );

1.源字符串必须以“\0”结尾

2.会将源字符串中的 '\0' 拷贝到目标空间

3.目标空间必须足够大,以确保能存放源字符串

4.目标空间必须可变

int main()
{char arr1[10] = "1234567";char arr2[20] = "0";printf("%s\n", arr2);strcpy(arr2, arr1);printf("%s\n",arr2);return 0;
}

模拟:

char* my_strcpy(char* destination, const char* source)
{assert(destination && source);char* ret = destination;while (*source){*destination = *source;destination++;source++;}return ret;
}

 因为我们的源地址,只是用来被拷贝,其指针指向的内容不能被改变,所以我们加上一个const修饰,而且,destination和source都不能是空指针,所以我们用assert断言一下。

 

1.2.2strcat
char * strcat ( char * destination, const char * source );

一个字符串从一个字符串的终止符号加上去

#include<stdio.h>
#include<string.h>int main()
{char arr[80] = { 0 };strcat(arr, " you ");strcat(arr, " are ");strcat(arr, " the ");strcat(arr, " best ");char arr1[20] = "ef";char arr2[] = "abcd";strcat(arr1,arr2);printf("%s\n" ,arr2);printf("%s\n", arr);return 0;
}

 我们来验证strcat是否是从目标字符串的终止符号(就是“\0”)来进行操作的

我们用上面的代码在vs2022上按快捷键f10,进行调试。

我们打开监视窗口,在窗口上输入arr1和arr2我们来进行观察

 

然后按下f10到14行位置,此时,arr1和arr2已经完成初始化。

 

我们的目标字符串是arr1,arr2是源字符串,此时我们按下f10

观察到arr1数组的第3个元素从" \0 "变成了字符‘ a ’,由此我们得以验证,strcat是从目标字符的终止字符“ \0 ”来进行操作的。

下面我们来模拟这个函数:

1.这个函数是用来把一个字符串放到另一个字符串的末尾

2.是从目标字符串的末尾来进行操作的

3.返回类型是目标字符串的起始地址

char* my_strcat(char* destination, const char* source)
{char ret = destination;while (*destination){destination++;}while ((*destination++ = *source++)){;}return ret;
}
1.2.3strcmp

int strcmp ( const char * str1, const char * str2 );

两个字符串进行比较,返回一个int类型的值

比较到出现另个字符不一样或者一个字符串结束或者n个字符全部比较完

如果出现第一个不一样的字符,第一个字符串的这个字符比第二个字符串的这个字符小就返回一个<0的数

如果出现第一个不一样的字符,第一个字符串的这个字符比第二个字符串的这个字符大就返回一个>0的数

如果比较结束都不一样就返回0;

int main()
{char arr1[] = "abcde";char arr2[] = "abcdf";int ret = strcmp(arr1, arr2);printf("%d ", ret);return 0;
}


int main()
{char arr1[] = "abcde";char arr2[] = "abcde";int ret = strcmp(arr1, arr2);printf("%d ", ret);return 0;
}

int main()
{char arr1[] = "abcdf";char arr2[] = "abcde";int ret = strcmp(arr1, arr2);printf("%d ", ret);return 0;
}

 

 我们下面来模拟这个函数

1.当两个字符串不同相同时,终止循环并进行比较

2.当2个字符串比完之后,终止循环并返回0

int my_strcmp(const char* str1, const char* str2)
{while ((*str1 == *str2) || *str1 != '\0'){str1++;str2++;}if (*str1 < *str2)return -1;else if(*str1 > *str2)return 1;else return 0;
}

1.3长度受限制的字符串函数介绍

1.3.1strncpy
char * strncpy ( char * destination, const char * source, size_t num );
拷贝 num 个字符从源字符串到目标空间。
如果源字符串的长度小于 num ,则拷贝完源字符串之后,在目标的后边追加 0 ,直到 num 个。

 

1.3.2strncat
char * strncat ( char * destination, const char * source, size_t num );

 

1.3.3strncmp
int strncmp ( const char * str1, const char * str2, size_t num );

 

1.4字符串查找

1.4.1strstr
const char * strstr ( const char * str1, const char * str2 );char * strstr (       char * str1, const char * str2 );

1.4.2strtok

char * strtok ( char * str, const char * delimiters );
sep 参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0 个或者多个由 sep 字符串中一个或者多个分隔符分割的标
记。
strtok 函数找到 str 中的下一个标记,并将其用
\0
结尾,返回一个指向这个标记的指针。(注: strtok函数会改变被操作的字符串,所以在使用 strtok 函数切分的字符串一般都是临时拷贝的内容并且可修改。)
strtok 函数的第一个参数不为 NULL ,函数将找到 str 中第一个标记, strtok 函数将保存它在字符串
中的位置。
strtok 函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标
记。
如果字符串中不存在更多的标记,则返回 NULL 指针。

1.5.错误信息报告

strerror

char * strerror ( int errnum );

返回错误码,所对应的错误信息。

 必须包含头文件#include<errno.h>

2.字符函数

1.字符分类函数

 函数如果他的参数符合以下条件就返回真
iscntrl
任何控制字符
isspace
空白字符:空格 ‘ ’ ,换页 ‘\f’ ,换行 '\n' ,回车 ‘\r’ ,制表符 '\t' 或者垂直制表符 '\v'
isdigit
十进制数字 0~9
isxdigit
十六进制数字,包括所有十进制数字,小写字母 a~f ,大写字母 A~F
islower
小写字母 a~z
isupper
大写字母 A~Z
isalpha
字母 a~z A~Z
isalnum
字母或者数字, a~z,A~Z,0~9
ispunct
标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph
任何图形字符
isprint
任何可打印字符,包括图形字符和空白字符

2.字符转换函数

 int tolower ( int c );

 int toupper ( int c );

#include<stdio.h>#include <ctype.h>
int main()
{int i = 0;char str[] = "Test String.\n";char c;while (str[i]){c = str[i];if (isupper(c))c = tolower(c);putchar(c);i++;}return 0;
}

3.内存函数

1.memcpy

void * memcpy ( void * destination, const void * source, size_t num );

这里我们发现,返回类型还有参数类型都是void*,这是为了方便接收任意指针,

函数memcpysource的位置开始向后复制num个字节的数据到destination的内存位置。这个函数在遇到 '\0' 的时候并不会停下来。如果sourcedestination有任何的重叠,复制的结果都是未定义的。

2.memmove

void * memmove ( void * destination, const void * source, size_t num );

3.memcmp

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/420008.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TCP Analysis Flags 之 TCP Port numbers reused

前言 默认情况下&#xff0c;Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态&#xff0c;并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时&#xff0c;会对每个 TCP 数据包进行一次分析&#xff0c;数据包按照它们在数据包列表中出现的顺序进行处理。可…

【AI绘画】Midjourney光影控制详解

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AI绘画 | Midjourney 文章目录 &#x1f4af;前言&#x1f4af;为什么要学习光影控制光影控制的作用 &#x1f4af;强化主题hard lighting&#xff08;硬光 &#xff09;soft lighting&#xff08;软光/柔光&#xff09;测试 &…

【Java 输入流详解:局部与全局定义及资源管理】

Java 输入流详解&#xff1a;局部与全局定义及资源管理 在Java编程中&#xff0c;输入流&#xff08;如Scanner类&#xff09;是读取用户输入的常用方式。通过Scanner&#xff0c;可以方便地读取不同类型的数据&#xff0c;比如整数、字符串等。作为基于输入流的工具&#xff0…

【非零段划分 / 2】

题目 思路 第一种思路&#xff1a;按照表面题意&#xff0c;枚举p&#xff0c;处理数组后进行计数&#xff1a; 复杂度 ∈ O ( n ⋅ m ) 复杂度 \in O(n \cdot m) 复杂度∈O(n⋅m) 第二种思路&#xff1a;把数组看成一个二维的山形图&#xff0c;先将相邻的水平线段转化成点…

一区霜冰算法+双向深度学习模型+注意力机制!RIME-BiTCN-BiGRU-Attention

一区霜冰算法双向深度学习模型注意力机制&#xff01;RIME-BiTCN-BiGRU-Attention 目录 一区霜冰算法双向深度学习模型注意力机制&#xff01;RIME-BiTCN-BiGRU-Attention效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现RIME-BiTCN-BiGRU-Attention霜冰算法…

如何本地搭建Whisper语音识别模型

要在本地搭建Whisper语音识别模型&#xff0c;您需要以下几个步骤&#xff1a; 步骤一&#xff1a;系统准备 操作系统: 建议使用Ubuntu 20.04或以上版本&#xff0c;确保系统足够稳定和兼容。硬件配置: 最好有一个强大的GPU&#xff0c;因为语音识别涉及大量的计算工作。推荐…

828华为云征文|华为云Flexus X实例部署k3s与kuboard图形化管理工具

828华为云征文&#xff5c;华为云Flexus X实例部署k3s与kuboard图形化管理工具 华为云最近正在举办828 B2B企业节&#xff0c;Flexus X实例的促销力度非常大&#xff0c;特别适合那些对算力性能有高要求的小伙伴。如果你有自建MySQL、Redis、Nginx等服务的需求&#xff0c;一定…

算法工程师重生之第二天(长度最小的子数组 螺旋矩阵II 区间和 开发商购买土地 总结 )

参考文献 代码随想录 一、长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的 子数组 [numsl, numsl1, ..., numsr-1, numsr] &#xff0c;并返回其长度。如果不存在符合条件的子数组&#xff0c…

全网最适合入门的面向对象编程教程:46 Python函数方法与接口-函数与事件驱动框架

全网最适合入门的面向对象编程教程&#xff1a;46 Python 函数方法与接口-函数与事件驱动框架 摘要&#xff1a; 函数是 Python 中的一等公民,是一种可重用的代码块,用于封装特定的逻辑&#xff1b;事件驱动框架是一种编程模式&#xff0c;它将程序的控制流转移给外部事件,如用…

ssm微信小程序校园失物招领论文源码调试讲解

第二章 开发技术与环境配置 以Java语言为开发工具&#xff0c;利用了当前先进的SSM框架&#xff0c;以MyEclipse10为系统开发工具&#xff0c;MySQL为后台数据库&#xff0c;开发的一个微信小程序校园失物招领。 2.1 Java语言简介 Java是由SUN公司推出&#xff0c;该公司于20…

若依框架使用MyBatis-Plus中的baseMapper的方法报错Invalid bound statement (not found):

Invalid bound statement (not found): com.ruoyi.system.mapper.hc.HcOrderMapper.selectList 解决方法 MybatisSqlSessionFactoryBean sessionFactory new MybatisSqlSessionFactoryBean(); 使用 MybatisSqlSessionFactoryBean 而非 SqlSessionFactoryBean 的原因 MyBatis-…

Elasticsearch数据写入过程

1. 写入请求 当一个写入请求&#xff08;如 Index、Update 或 Delete 请求&#xff09;通过REST API发送到Elasticsearch时&#xff0c;通常包含一个文档的内容&#xff0c;以及该文档的索引和ID。 2. 请求路由 协调节点&#xff1a;首先&#xff0c;请求会到达一个协调节点…

1分钟教你用AI制作美女热舞视频,收益可观,操作简单(附工具及教程资料)

美女跳舞&#xff0c;听着是不是就觉得会很哇塞&#xff1f; 不管是男的女的、老的少的都喜欢看&#xff0c;而且一般美女跳舞的账号涨粉都很快&#xff0c;势头都贼猛。 今天就给大家分享一个很热门的小副业——AI美女跳舞。 更多实操和AI绘画工具&#xff0c;可以扫描下方&…

新能源动力组中预充电路及电阻选型分析

新能源动力组中预充电路及电阻选型分析 1.概述2.预充电路与预充电阻3.预充电阻参数选择4.实例分析 1.概述 最近几年&#xff0c;新能源行业在中国得到迅猛发展。由于其高效、节能、低噪声、无污染等特点&#xff0c;它已成为国内工业发展的新趋势包括汽车和飞机。虽然应用在新…

地瓜直播间 | 基于X5平台智能双目深度算法详解

你是否曾经好奇过&#xff0c;机器是如何像人类一样通过双眼来感知三维世界的&#xff1f;双目深度感知技术&#xff0c;是一种模拟人类双眼视觉的高级技术&#xff0c;通过两个摄像头捕捉同一场景的不同视角&#xff0c;深度学习算法能够计算出物体的深度信息&#xff0c;从而…

PX4软/硬件(SITL/HITL)在环仿真

文章目录 介绍依赖PX4 Firmware&#xff1a; 软件在环(SITL)仿真Gazebo 软件无人机STIL连接简要示意SITL SLAM仿真总结示例 HITL 仿真 pxh常用命令MAVLink 指令使用这些命令时的注意事项 参考链接 介绍 为https://blog.csdn.net/weixin_41469272/article/details/117919845的补…

东南亚电商新蓝海:深度解析东南亚服务器租用的战略价值

在全球化日益加深的今天&#xff0c;东南亚以其独特的市场潜力和对数字化技术的积极拥抱&#xff0c;成为了跨境电商及互联网企业竞相角逐的热土。随着东南亚地区经济的快速增长和人口红利的持续释放&#xff0c;电商市场的繁荣景象尤为引人注目。然而&#xff0c;要在这一竞争…

【Linux系统编程】TCP实现--socket

使用套接字socket实现服务器和客户端之间的TCP通信。 流程如下&#xff1a; 实现代码&#xff1a; /* server.c */ #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <arpa/inet.h> #include <s…

【C++笔记】类和对象的深入理解(一)

【C笔记】类和对象的深入理解(一) &#x1f525;个人主页&#xff1a;大白的编程日记 &#x1f525;专栏&#xff1a;C笔记 文章目录 【C笔记】类和对象的深入理解(一)前言一.类的定义1.1类定义格式1.2访问限定符1.3类域 二.实例化2.1 实例化概念2.2对象大小 三.this指针四.练…

[A-09]ARMv8/ARMv9-Memory-内存空间(Address Spaces and Translation Regimes)

ver 0.2 更多精彩内容&#xff0c;请关注公众号 前言 任何人和组织的发展都需要空间&#xff0c;比如我们这个伟大的国家&#xff0c;幅员辽阔、大好河山决定了我们的发展潜力。这么大国土空间&#xff0c;不是随意无须的在发展&#xff0c;都是处于主动的规划(有形的手)或者…