一,memcpy的使用和模拟实现
1,memcpy的使用
memcpy为内存拷贝函数,它的声明如下:
void* memcpy (void* destination ,const void* source, size_t num)
其中两个参数为void*类型,可以用来接收任意类型的数据。
拷贝方式为:memcpy函数从source开始向后复制num个字节到destination。
注:该函数在遇到‘\0'时,不会停止拷贝。且该函数不支持在数据重叠情况下试用。
int main()
{
int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
memcpy(arr2, arr1, 20);
for (int i = 0; i < 10; i++)
printf("%d ", arr2[i]);
}
该程序是将 数组arr1中20个字节数据拷贝到数组arr2中,也就是拷贝5个元素
代码的运行结果是:1 2 3 4 5 0 0 0 0 0
2,memcpy的模拟实现
void* my_memcpy(void* dest, const void* scr, size_t num)
{
//将scr中num个字节拷贝到dest中
while (num--)//循环次数
{
*(char*)dest = *(char*)scr;//void*类型的指针不能直接进行解引用,故先转换成char*指针,同时char*指针在解引用时,访问一个字节
dest = (char*)dest+1;//void*类型的指针不能进行+-,故先转换成char*,再加1使指针向后移动
scr = (char*)scr + 1;
}
}
int main()
{
int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
my_memcpy(arr2, arr1, 20);
for (int i = 0; i < 10; i++)
printf("%d ", arr2[i]);
}
二,memmove的使用和模拟实现
1,memmove的使用
和memcpy相比,memmove函数处理的两个数据可以是重叠的。
将3,4,5,6,7这5个元素拷贝到1,2,3,4,5
2,memmove的模拟实现
由图可以看出,当dest>scr时,数据需要从前往后拷贝,才能达到效果,若是从后往前拷贝,会使数据被覆盖而达不到想要的效果。那么,当dest<scr时,就需要从后往前拷贝。
模拟实现如下:
这里,从前往后拷贝时,是和memcpy函数一样的。
三,memset函数
void* memset (void* ptr,int value,size_t num)
memset是内存设置函数,将内存中的值以字节为单位设置成想要的内容,这里的num是以字节为单位的。
使用如下:
int main()
{
char arr[] = "hello word";
memset(arr, 'x', 6);
printf("%s\n", arr);
}
代码结果为xxxxxxword
四,memcpy的使用
int memcpy(const void*ptr1,const void* ptr2,size_t num)
比较从ptr1和ptr2开始,向后的num个字节的大小。
返回值如下:
ptr1<ptr2时,返回小于0的数字;
ptr1=ptr2时,返回0;
ptr1>ptr2时,返回大于0的数字。
感谢各位的观看,有什么问题还请指教,我会不断学习改进的。