memcpy
定义:void * memcpy ( void * destination, const void * source, size_t num );
注意事项:
1.函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
2.这个函数在遇到 ‘\0’ 的时候并不会停下来。
3.如果source和destination有任何的重叠,复制的结果都是未定义的。
(因为复制的时候改变了数组本身,就发生了错误)
并且函数返回的是目标的地址
这里最重要的是这个函数是一个字节一个字节的复制的
所以比如设定了一个int类型的数组,int[]={1,164466};而我们使用memcpy的时候形参部分size_t num写的5,这个时候数组中的第二个元素就无法完全辅助到目标地址
下面我们来模拟实现该函数:
#include<stdio.h>
#include<assert.h>
void* my_memcpy(void* dst, const void* src, size_t num)
{
void* p = dst;
assert(dst && src);
while (num--)
{
*(char*)dst = *(char*)src;
dst = (char*)dst+1;
src = (char*)src + 1;
}
return p;
}
int main()
{
int arr1[] = { 1,2,3,4,5,6 };
int arr2[10] = { 0 };
int i = 0;
my_memcpy(arr2, arr1, 22);
for (i = 0; i < 10; i++)
{
printf("%d ", arr2[i]);
}
}
memmove
定义:void * memmove ( void * destination, const void * source, size_t num );
该函数和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。
如下面这个例子:
就可以对数组自己本身使用。
下面我们同样来模拟实现该函数:
为了方便理解这个库函数的实现,我们来画个图解释一下:
我们创建一个数组,存放1~8,红色方框里是我们的目标,而黄色方框是源,就是要把红色方框里的数字变成黄色方框里的数字,那要怎么才能实现呢?我们来看,如果我们先把4变为6,3变成5,那2这个时候呢,第一步已经把4用6覆盖掉了,所以2就不能变为4了,这种我们就叫从后往前变化吧;那我们如果从前往后的话,先把2变成4,3变成5,然后4变为6,这种方法就能成功。
同理可得,如果我们把黄色的方框里当成目标,而红色方框当成源的话,我们就需要从后往前变化。
所以我们就总结出当dst<str的时候,从前往后变化,而当dst>=str的时候,我们从后往前变化。
下面我们就来模拟实现该函数:
void* my_memmove(void* dst, const void* str, size_t num)
{
char* ret = dst;
if (dst < str)
{
while (num--)
{
*(char*)dst = *(char*)str;
dst = (char*)dst + 1;
str = (char*)str + 1;
}
}
else
{
while (num--)
{
*((char*)dst + num) = *((char*)str + num);
}
}
return ret;
}
int main()
{
int arr[6] = { 1,2,3,4,5,6 };
int i = 0;
my_memmove(arr + 2, arr, 12);
for (i = 0; i < 6; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
memcmp
定义:int memcmp ( const void * ptr1, const void * ptr2, size_t num );
要注意的是这里的比较也是一个字节一个字节的比较
如下面的例子:
相当于这里比较3和257的第一个字节
而3的第一个字节是03,而257的第一个字节是01,所以判定的是arr1>arr2.
memset
定义:void * memset ( void * ptr, int value, size_t num );
作用是:
将 ptr 指向的内存块的第一个字节数设置为指定值
这里的设置也是以字节为单位的!
继续看一个例子
这里就是把arr里的每一个元素的每一个字节都设成了1,并不是把每个元素设置成1这样.
以上就是C语言中的一些常见的内存函数,如有错误,欢迎指正!谢谢!