C语言内存函数之 memcpy和memmove函数

memcpy函数的记忆方法:mem表示内存类函数,属于头文件string.h里面的函数。cpy是copy的缩写,表示对内存数据进行拷贝。

memcpy函数的输入值和返回值:void* my_memcpy(void*brr,void*arr,size_t v) memcpy的输入值分别是被拷贝数据的brr的无类型数组的首地址,然后是拷贝给别人的无类型数组的首地址arr,最后是size_t类型的需要拷贝的字节数v。

memcpy函数的自我实现:

void* my_memcpy(void*brr,void*arr,size_t v){

for (int x = 0; x < v; x++) { //用v来限制x的自增大小最值,x来确定拷贝的地方

*((char*)brr + x) = *((char*)arr + x); //用强制类型转换来一个字节一个字节的拷贝,以char类 型来强制类型转换刚好可以一个字节一个字节的搬运内 存数据。

}

return brr; //最后返回无类型的地址brr,所以接受的时候注意强制类型转换

}

**memmove函数的记忆方法:**mem表示内存类函数,属于头文件string.h里面的函数。move表示搬运,和拷贝的意思是差不多的,但是它复制的方向和memcpy不同。

memmove函数的传入值和返回值:void* my_memmove(void* brr, void* arr, size_t v)

这里 和strcpy函数是相同的。

memmove函数的自我实现:

void* my_memmove(void* brr, void* arr, size_t v) {

for (int x = v - 1; x >= 0; x--) { //这里就是把赋值的顺序反过来了

*((char*)brr + x) = *((char*)arr + x);

}

return brr;

}

为什么要这么能呢?

肯定有其原因:

如果现在你要把123向后移动两位,你要怎么做呢?如果你是把1先放在3处,再把2放在4处,你要移动3发现你的3被1覆盖了。所以这里就可以看出我们从前向后复制是不能用memcpy的。那么我们用memmove呢,先移动3到5,再移动2到4,再是1到3。发现完全没有问题。那么如果我们把3 4 5向前移动2位能不能用memmove呢,答案是不行的,你们可以自行试一试。这里就要相反来搞了,用memcpy。

那么我们能不能自己设定一个函数来将两个函数的功能结合起来呢?

当然是可以的。我们观察上面两种情况,发现就是一个在前一个在后的问题,在前的如果复制到后面去就要先从后面赋值。反之就应该前面的先复制到前面去。

代码实现:

做一个判断就行了。

相关推荐
曙曙学编程10 小时前
stm32——独立看门狗,RTC
c语言·c++·stm32·单片机·嵌入式硬件
晨非辰11 小时前
#C语言——刷题攻略:牛客编程入门训练(九):攻克 分支控制(三)、循环控制(一),轻松拿捏!
c语言·开发语言·经验分享·学习方法·visual studio
陈序猿(代码自用版)11 小时前
【考研C语言编程题】数组元素批量插入实现(含图示+三部曲拆解)
c语言·开发语言·考研
77qqqiqi11 小时前
学习循环语句
c语言
kyle~11 小时前
排序---冒泡排序(Bubble Sort)
c语言·c++·算法
l1t11 小时前
我改写的二分法XML转CSV文件程序速度追上了张泽鹏先生的
xml·c语言·人工智能·算法·expat
wdfk_prog13 小时前
[Linux]学习笔记系列 -- lib/dump_stack.c 栈回溯打印(Stack Trace Dumping) 内核调试与错误诊断的基石
linux·运维·服务器·c语言·笔记·学习
刃神太酷啦13 小时前
C++ 异常处理机制:从基础到实践的全面解析----《Hello C++ Wrold!》(20)--(C/C++)
java·c语言·开发语言·c++·qt·算法·leetcode
CYRUS_STUDIO13 小时前
OLLVM 移植 LLVM18 踩坑:一步步调试修复控制流平坦化
c语言·c++·llvm
10001hours14 小时前
C语言第12讲
c语言·开发语言