【C语言】面试常考----- 内存函数memcpy和memmove的功能区别与模拟实现

1.memcpy

功能:把source指向的前num个字节内容拷贝到destination指向的位置去,可以拷贝任意类型的数据。

注:1.memcpy并不关心\0,毕竟传的也不一定是字符串,因此拷贝过程中遇到\0也不会停下来。

2.num的单位是字节,并不是要拷贝的元素个数

3.如果source和destination有任何的重叠,拷贝的结果都是未定义的。什么意思呢?举个例子,我现在要把arr1中的12345拷贝到34567的位置上去。

打印结果却并没有如愿,这是因为当我们把1拷贝到了3的位置上,2拷贝到了4的位置上,数组arr1的内容已经被改变了,当我们要拷贝3到5的位置上时,3已经变成了1,于是就把1拷贝过去了。于是出现了上图所示的情况。

也就是说memcpy只用于处理不重叠内存的数据。

模拟实现memcpy

像这种能够操作各种类型数据的函数,其底层实现原理基本上都和char*类型的指针有关系,比如memcpy,还有我们前面已经模拟实现过的库函数qsort。因为char*类型的指针走一步就跳过一个字节,字节又是内存单元的最小单位,不管是什么类型的数据,只要一个字节一个字节的操作,最终都可以达成目的。

因此在这里我们就把des和src两个指针强制类型转换成char*类型的,然后解引用对他们指向的那一个字节单元的内容进行赋值操作,赋值完一个字节之后再进行下一个字节单元的操作。注意强制类型转换只是一个临时的操作,并不是说我们在进行赋值的时候把des和src强制类型转换成char*类型的了,他就一直是char*类型的了,因此要让des和src指向下一个字节单元,应该写成des=(char*)des+1。

2.memmove

功能:也是拷贝内存数据

和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。如果源空间和目标空间出现重叠,就得使用memmove函数处理。

像刚才那个例子,我们就可以使用memmove解决

模拟实现memmove

思路:要在有重叠的数据里面实现拷贝,最大的问题就是在拷贝的过程中会改变原来位置的内容,第一想法是可以申请一块内存在里面存放原本数据的相同内容,这样当然可以,但是第一这种写法比较麻烦,第二会造成内存的浪费。能不能不申请内存就实现在同一块内存中拷贝内容呢?

当然可以,举个例子,12345678这串数字,现在我要把345处的内容拷贝成123,也就是最终让数字变成12123678,此时des在src的后面,如果我先把1拷贝到3的位置,那么后面在想把3拷贝到6处时就很尴尬,因为此时的3已经变成了1,但是如果我倒着拷贝,先把3拷贝到6的地方,再把2拷贝到5的地方,再把1拷贝到3的地方,不就行了吗?

再举一个例子,如果我要把345拷贝到123的位置,此时des在src的前面,我们直接把3拷贝到1的位置,4拷贝到2的位置,5拷贝到3的位置即可。

也就是说,如果dessrc,就从后往前拷贝。如果两块数据没有重叠,那从前或者从后都可以。

在代码中从后往前找的时候,先判断num是否为0,然后--,第一次的时候num是20,进入循环之后已经--了,变成了19,因此(char*)des + num与(char*)src + num都指向了最后一个要拷贝的位置。并随着num的减小不断指向前面位置。

注:memcpy能做的,memmove都能做。但是memmove能做的,memcpy不一定能做。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

正大国际期货:银行再掀“压岁钱”争夺战 儿童金融服务还有哪些发力空间

随着春节假期渐入尾声,如何打理过年期间累积的“小金库”成为家长和孩子共同关注的话题,不少银行瞄准这一需求针对压岁钱展开营销。2月20日,北京商报记者调查发现,多家银行通过推出专属存款产品或定制银行卡等方式吸引储户目光。 …

C# CAD交互界面-模态窗体与非模态窗体调用方式

运行环境Visual Studio 2022 c# cad2016 一、模态窗体调用方式: 当一个模态窗体打开时,它会阻塞主窗体的所有输入,直到关闭该模态窗体为止。例如,弹出一个对话框让用户必须完成某些操作后才能继续使用主程序。 [CommandMethod(&q…

击败.helper勒索病毒:恢复被加密的数据文件的方法

导言: 近年来,勒索病毒成为网络安全领域的一大威胁,其中.helper勒索病毒更是备受关注。该类型的勒索软件以其高效的加密算法,能够将用户的文件加密,迫使用户支付赎金才能解密数据。本文将介绍.helper勒索病毒的特点、恢复被加密数…

Howler.js:音频处理的轻量级解决方案

文章目录 Howler.js:音频处理的轻量级解决方案引言一、Howler.js简介1.1 特性概览 二、Howler.js基本使用使用详解2.1 创建一个Howl对象2.2 控制音频播放2.3 监听音频事件 三、进阶功能3.1 音频Sprites3.2 3D音频定位 四、微前端场景下的Howler.js Howler.js&#x…

51_蓝桥杯_独立按键

一 电路 注意:J5跳帽接到2~3引脚,使按键S4-S5四个按键的另外一端接地,从而成为4个独立按键。 二 独立按键工作原理 三 代码 代码1:按下S7点亮L1指示灯,松开按键,指示灯熄灭,按下S6点亮L2指示灯…

Java 绘图

一、坐标体系 二、快速入门(画圆) import javax.swing.*; import java.awt.*;SuppressWarnings({"all"}) public class DrawCircle extends JFrame { //JFrame 对应窗口,可以理解成是一个画框private MyPanel mp null; //定义一个面板pu…

Google的firebase简介

文章目录 firebase简介firebase的一些特点 firebase简介 Firebase是一项由Google提供的云服务,旨在帮助开发者构建高质量的应用程序。Firebase 提供了各种工具和服务,涵盖了应用开发的多个方面,包括实时数据库、认证、云存储、云函数、推送通…

stable diffusion官方版本复现

踩了一些坑,来记录下 环境 CentOS Linux release 7.5.1804 (Core) 服务器RTX 3090 复现流程 按照Stable Diffusion的readme下载模型权重、我下载的是stable-diffusion-v1-4 版本的 1 因为服务器没法上huggingface,所以得把权重下载到本地&#xff…

js中使用for in注意事项,key的类型为string类型

for in是一个非常实用的存在,既可以遍历数组,又可以遍历对象,所以我一般都是会用来遍历可迭代的数据,遍历数组和对象的时候,要注意使用万能遍历方式: const users [1, 3, 45, 6]// const users {// 1…

Unity3D中刚体、碰撞组件、物理组件的区别详解

前言 Unity3D提供了丰富的功能和组件,其中包括刚体、碰撞组件和物理组件。这些组件在游戏开发中起着非常重要的作用,能够让游戏世界更加真实和有趣。本文将详细介绍这三种组件的区别以及如何在Unity3D中实现它们。 对惹,这里有一个游戏开发…

【论文阅读|基于 YOLO 的红外小目标检测的逆向范例】

基于 YOLO 的红外小目标检测的逆向范例 摘要1 引言2 相关工作2.1 逆向推理2.2 物体检测方法 3 方法3.1 总体架构3.2 逆向标准的可微分积分 4 实验4.1 数据集和指标4.2 实验环境4.4 OL-NFA 为少样本环境带来稳健性 5 结论 论文题目: A Contrario Paradigm for YOLO-b…

用CSS3画一个三角形

<style> .up{width:0;height:0;border: 100px solid transparent;border-top: 100px solid red;/*红色*/ } .down{width:0;height:0;border: 100px solid transparent;border-bottom: 100px solid blue;/*蓝色*/ } .left{width:0;height:0;border: 100px solid transpare…

python coding with ChatGPT 打卡第21天| 二叉树:最近公共祖先

相关推荐 python coding with ChatGPT 打卡第12天| 二叉树&#xff1a;理论基础 python coding with ChatGPT 打卡第13天| 二叉树的深度优先遍历 python coding with ChatGPT 打卡第14天| 二叉树的广度优先遍历 python coding with ChatGPT 打卡第15天| 二叉树&#xff1a;翻转…

【经验分享】分类算法与聚类算法有什么区别?白话讲解

经常有人会提到这个问题&#xff0c;从我个人的观点和经验来说2者最明显的特征是&#xff1a;分类是有具体分类的数量&#xff0c;而聚类是没有固定的分类数量。 你可以想象一下&#xff0c;分类算法就像是给你一堆水果&#xff0c;然后告诉你苹果、香蕉、橙子分别应该放在哪里…

BUUCTF crypto做题记录(7)新手向

一、Dangerous RSA 得到的密文如下 首先&#xff0c;我们对n进行大数分解看行不行。 其次&#xff0c;我们可看一下数的特征&#xff08;除了一些基础题&#xff0c;一般情况下n都是分解不了的&#xff0c;应该首先观察一下数据特征&#xff0c;我很久没做RSA了&#xff0c;有…

vue3前端项目开发,具备纯天然的防止爬虫采集的特征

vue3前端项目开发,具备纯天然的防止爬虫采集的特征&#xff01;众所周知&#xff0c;网络爬虫可以在网上爬取到一些数据&#xff0c;很多公司&#xff0c;为了自己公司的数据安全&#xff0c; 尤其是web端项目&#xff0c;不希望被爬虫采集。那么&#xff0c;您可以使用vue技术…

设计模式: 策略模式

文章目录 一、什么是策略模式二、策略模式结构三、使用场景案例分析1、使用场景2、案例分析&#xff08;1&#xff09;消除条件分支 一、什么是策略模式 策略模式是一种行为型设计模式&#xff0c;它允许定义一组算法&#xff0c;并将每个算法封装在独立的类中&#xff0c;使它…

学习鸿蒙基础(4)

1.条件渲染 ArkTS提供了渲染控制的能力。条件渲染可根据应用的不同状态&#xff0c;使用if、else和else if渲染对应状态下的UI内容。 当if、else if后跟随的状态判断中使用的状态变量值变化时&#xff0c;条件渲染语句会进行更新。。 Entry Component struct PageIfElse {Stat…

LeetCode Python - 29.两数相除

目录 题目答案运行结果 题目 给你两个整数&#xff0c;被除数 dividend 和除数 divisor。将两数相除&#xff0c;要求 不使用 乘法、除法和取余运算。 整数除法应该向零截断&#xff0c;也就是截去&#xff08;truncate&#xff09;其小数部分。例如&#xff0c;8.345 将被截…

vscode更改代码背景

安装插件&#xff1a;background-cover 安装成功后vscode的右下角出现一个标&#xff1a; 点击后选择图片就行了