【C语言】常用库函数的介绍与模拟实现(有手就行)——— 字符 / 字符串 库函数

简介: 【C语言】常用库函数的介绍与模拟实现(有手就行)——— 字符 / 字符串 库函数

image.png

【C语言】字符 / 字符串 库函数的模拟实现

strlen函数

函数介绍

函数声明:

size_t strlen(const char *str)

作用:

计算字符串 str 的长度,直到空结束字符,但不包括空结束字符

参数:

str – 要计算长度的字符串。

返回值:

该函数返回字符串的长度。

  • 字符串已经 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )。
  • 参数指向的字符串必须要以 ‘\0’ 结束。
  • 注意函数的返回值为size_t,是无符号的( 易错 )

重写模拟实现

以下附上三种实现方法

image.png

strcpy函数

函数介绍

函数声明:

char *strcpy(char *dest, const char *src)

作用:

把 src 所指向的字符串复制到 dest

参数:

dest – 指向用于存储复制内容的目标数组。

src – 要复制的字符串。

返回值:

该函数返回一个指向最终的目标字符串 dest 的指针。

  • 源字符串必须以 ‘\0’ 结束。
  • 会将源字符串中的 ‘\0’ 拷贝到目标空间。
  • 目标空间必须足够大,以确保能存放源字符串
  • 目标空间必须可变。

重写模拟实现

image.png

strcat函数

函数介绍

函数声明:

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

作用:

把 src 所指向的字符串追加到 dest 所指向的字符串的结尾。

参数:

dest – 指向目标数组,该数组包含了一个 C 字符串,且足够容纳追加后的字符串。

src – 指向要追加的字符串,该字符串不会覆盖目标字符串。

返回值:

该函数返回一个指向最终的目标字符串 dest 的指针。

  • 源字符串必须以 ‘\0’ 结束
  • 目标空间必须有足够的大,能容纳下源字符串的内容。
  • 目标空间必须可修改。

重写模拟实现

image.png

strcmp函数

函数介绍

函数声明:

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

作用:

把 str1 所指向的字符串和 str2 所指向的字符串进行比较。

参数:

str1 – 要进行比较的第一个字符串。

str2 – 要进行比较的第二个字符串。

该函数返回值如下:


如果返回值小于 0,则表示 str1 小于 str2。

如果返回值大于 0,则表示 str1 大于 str2。

如果返回值等于 0,则表示 str1 等于 str2。

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

重写模拟实现

image.png

strstr函数

函数介绍

函数声明:

char *strstr(const char *haystack, const char *needle)

作用:

在字符串 haystack 中查找第一次出现字符串 needle 的位置,不包含终止符 ‘\0’。

参数:

haystack – 要被检索的 C 字符串。 needle – 在 haystack 字符串内要搜索的小字符串。

返回值:

该函数返回在 haystack 中第一次出现 needle 字符串的位置,如果未找到则返回 null。


重写模拟实现

这里用到的是BF算法,将目标字符串跟原字符串依次作比较,找到子串,理解较为简单

(其实还可以用KMP算法来写)

image.png

memcpy函数

函数介绍

函数声明:

void *memcpy(void str1, const void str2, size_t n)

作用:

从存储区str2 复制 n 个字节到存储区 str1。

参数:

str1 – 指向用于存储复制内容的目标数组,类型强制转换为 void 指针。

str2 – 指向要复制的数据源,类型强制转换为 void 指针。

n – 要被复制的字节数。

返回值:

该函数返回一个指向目标存储区 str1 的指针。


函数memcpy从str2的位置开始向后复制n个字节的数据到str1的内存位置。

这个函数在遇到 ‘\0’ 的时候并不会停下来。

如果str1和str2有任何的重叠,复制的结果都是未定义的。

重写模拟实现

image.png

memmove函数

函数介绍

函数声明:

void *memmove(void str1, const void str2, size_t n)

作用:

从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。

参数:

str1 – 指向用于存储复制内容的目标数组,类型强制转换为 void 指针。

str2 – 指向要复制的数据源,类型强制转换为 void 指针。

n – 要被复制的字节数。

返回值:

该函数返回一个指向目标存储区 str1 的指针。


和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。

如果源空间和目标空间出现重叠,就得使用memmove函数处理。

重写模拟实现

重写的时候必须要分清楚情况:

image.png

所以模拟memmove函数的核心重点在于

image.png

image.png















相关文章
|
12天前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
50 24
|
7天前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
46 16
|
7天前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
19 3
|
7天前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
11 2
|
11天前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
41 1
|
C语言 图形学 数据格式
C语言库函数大全及应用实例一
原文:C语言库函数大全及应用实例一                                 [编程资料]C语言库函数大全及应用实例一 函数名: abort 功 能: 异常终止一个进程 用 法: void abort(void); 程序例: #i nclude #i nclude .
924 0
|
C语言 图形学 数据格式
C语言库函数大全及应用实例一
[编程资料]C语言库函数大全及应用实例一 函数名: abort 功 能: 异常终止一个进程 用 法: void abort(void); 程序例: #i nclude #i nclude int main(void...
787 0
|
移动开发 图形学 C语言
C语言库函数大全及应用实例二
[编程资料]C语言库函数大全及应用实例二 函数名: bioskey 功 能: 直接使用BIOS服务的键盘接口 用 法: int bioskey(int cmd); 程序例: #i nclude #i...
657 0
|
C语言 图形学 数据格式
C语言库函数大全及应用实例三
[编程资料]C语言库函数大全及应用实例三 函数名: ecvt 功 能: 把一个浮点数转换为字符串 用 法: char ecvt(double value, int ndigit, int *decpt, int *sign); 程序例: #i nclude #i nclude #i nc...
670 0
|
图形学 C语言
C语言库函数大全及应用实例四
[编程资料]C语言库函数大全及应用实例四 couble fmod (double x, double y); 返回x对y的模,即x/y的余数。
979 0

热门文章

最新文章