当前位置: 首页 > news >正文

C语言零基础第16讲:内存函数

目录

1.memcpy的使用和模拟实现

2.memmove的使用和模拟实现

3.memset的使用

4.memcmp的使用


正文开始

1.memcpy的使用和模拟实现

        memcpy函数的原型如下:

void* memcpy (void* destination, const void* source, size_t num);
  1. 从source的位置开始向后复制num个字节的数据,拷贝到destination指向的内存空间。
  2. 这个函数在遇到'\0'的时候并不会停下来。
  3. 如果source和destination有重叠的内存空间,在有的编译器上可以完成重叠的拷贝,达到预期效果,在有的编译器上不能完成
  4. memcpy函数会返回目标空间destination的起始地址。
  5. 对应的头文件:string.h。  

        我们来看一个示例:

        我们来看一下memcpy函数的模拟实现:

        但是,我们会发现,其实上述代码是有局限性的:

        如上,我们发现,没有达到预期的效果。

        如上,我们发现memcpy函数是可以达到预期效果的。

        其实,memcpy这个库函数,处理的是不重叠的两块内存数据的拷贝,在有的编译器上可以完成重叠的拷贝,在有的编译器上不能完成。

        如果想要完成重叠内存的拷贝,可以使用memmove函数。

2.memmove的使用和模拟实现

        memmove函数的原型如下:

void* memmove (void* destination, const void* source, size_t num);
  1. 和memcpy的区别在于,memmove函数处理的源内存空间和目标内存空间是可以重叠的。
  2. memmove既可以处理重叠的,又可以处理不重叠的。
  3. 对应的头文件:string.h。 

        我们来看一个示例:

        那么,如何模拟实现这个函数呢?

        观察一下,如果dest < source,无论是否重叠,我们都可以采用从前往后的拷贝方式。

        以memmove(arr, arr+2, 20)为例,我们想实现3、4、5、6、7、6、7、8、9、10的效果,可以从前往后拷贝:

        再观察一下,如果dest > source,重叠时可以采用从后往前拷贝的方式,不重叠时,既可以从前往后,又可以从后往前。       

        以memmove(arr+2, arr, 20)为例,我们想实现1、2、1、2、3、4、5、8、9、10的效果,可以从后往前拷贝:

        于是乎,我们可以这样写代码:

        我们来测试一下:

3.memset的使用

        memset函数的原型如下:

void* memset (void* ptr, int value, size_t num);

          我们来看一个示例:

  1. memset函数是用来设置内存的,以字节为单位,将内存中的值设置成想要的内容。
  2. ptr指向被设置的内存块。
  3. value为要设置的值。
  4. num表示有多少个字节要被设置为这个值。
  5. 对应的头文件:string.h。

        我们再看一个情况:

4.memcmp的使用

        memcmp函数的原型如下:

int memcmp (const void* ptr1, const void* ptr2, size_t num);
  1. 从ptr1和ptr2指向的位置开始,比较向后的num个字节。
  2. 如果是数字类数据,比较的是内存里的二进制值。
  3. 如果是非数字类数据,如字符,比较的是ASCII码值。
  4. 返回值有3种情况:<0、0、>0。
  5. 对应的头文件:string.h。

        我们来看一个示例:

        我们再来看一个示例:


完结

http://www.lryc.cn/news/620603.html

相关文章:

  • 华为实验WLAN 基础配置随练
  • 【奔跑吧!Linux 内核(第二版)】第6章:简单的字符设备驱动(三)
  • 使用AI编程自动实现自动化操作
  • 考研408《计算机组成原理》复习笔记,第三章(6)——Cache(超级重点!!!)
  • [免费]基于Python的影视数据可视化分析系统(Flask+echarts)【论文+源码+SQL脚本】
  • 财务自动化软件敏感数据泄露风险评估与防护措施
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘arviz’问题
  • Flutter 顶部导航标签组件Tab + TabBar + TabController
  • Polyak-Ruppert 平均
  • 第四天~什么是ARXML?
  • Eureka故障处理大汇总
  • Java研学-RabbitMQ(八)
  • 李沐-第六章-LeNet训练中的pycharm jupyter-notebook Animator类的显示问题
  • 【LeetCode 热题 100】295. 数据流的中位数——最大堆和最小堆
  • 基于Django的福建省旅游数据分析与可视化系统【城市可换】
  • AI 编程实践:用 Trae 快速开发 HTML 贪吃蛇游戏
  • 【经验分享】如何在Vscode的Jupyter Notebook中设置默认显示行号
  • vscode的wsl环境,ESP32驱动0.96寸oled屏幕
  • 【面板数据】各省及市省级非物质文化遗产数据合集(2005-2024年)
  • 【JavaEE】多线程 -- 初识线程
  • Java应用快速部署Tomcat指南
  • **超融合架构中的发散创新:探索现代编程语言的挑战与机遇**一、引言随着数字化时代的快速发展,超融合架构已成为IT领域的一种重要趋势
  • ts概念讲解
  • 网络原理-HTTP
  • 一致性哈希Consistent Hashing
  • 【代码随想录day 20】 力扣 669. 修剪二叉搜索树
  • 力扣-64.最小路径和
  • 玩转Docker | 使用Docker部署JSON格式化工具ZJSON
  • iOS Sqlite3
  • 磁盘瓶颈现形记 - iostat让I/O压力无所遁形