1. memcpy函数
描述
C 库函数 void *memcpy(void *str1, const void *str2, size_t n) 从存储区 str2 复制 n 个字节到存储区 str1。
声明
下面是 memcpy() 函数的声明。
void *memcpy(void *str1, const void *str2, size_t n)
参数
str1 -- 指向用于存储复制内容的目标数组,类型强制转换为 void* 指针。
str2 -- 指向要复制的数据源,类型强制转换为 void* 指针。
n -- 要被复制的字节数。
返回值
该函数返回一个指向目标存储区 str1 的指针
实例:
//内存函数使用//memcpy(内存拷贝函数)intmain() { intarr1[10] = { 1,2,3,4,5,6 }; intarr2[10] = { 0 }; memcpy(arr2, arr1, 12); for (inti=0; i<3; i++) { printf("%d ", arr2[i]); } return0; }
运行结果:
我们可以看到,memcpy实际上是一个拷贝函数,但是它与strcpy函数有所不同,一是参数不同,二是memcpy可以拷贝任意类型的数据,因为它的接收类型是void。
void*my_memcpy(void*dest, constvoid*src, intnum) { assert(dest); assert(src); void*ret=dest; while (num--) { *(char*)dest=*(char*)src; dest= (char*)dest+1; src= (char*)src+1; } returnret; } intmain() { intarr1[10] = { 1,2,3,4,5,6,7,8,9 }; intarr2[10] = { 0 }; my_memcpy(arr2, arr1, 20); inti=0; for (i=0; i<5; i++) { printf("%d ", arr2[i]); } return0; }
2.memmove函数
描述
C 库函数 void *memmove(void *str1, const void *str2, size_t n) 从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。
声明
下面是 memmove() 函数的声明。
void *memmove(void *str1, const void *str2, size_t n)
参数
str1 -- 指向用于存储复制内容的目标数组,类型强制转换为 void* 指针。
str2 -- 指向要复制的数据源,类型强制转换为 void* 指针。
n -- 要被复制的字节数。
返回值
该函数返回一个指向目标存储区 str1 的指针。
实例:
intmain() { intarr1[10] = { 1,2,3,4,5,6,7,8 }; memmove(arr1+3,arr1, 12); inti=0; for (i=0; i<8; i++) { printf("%d ", arr1[i]); } return0; }
运行结果:
模拟实现memmove:
void*my_memmove(void*dest, constvoid*src, intnum) { assert(dest); assert(src); void*ret=dest; if (dest<src) { while (num--) { *(char*)dest=*(char*)src; dest= (char*)dest+1; src= (char*)src+1; } } else { while (num--) { *((char*)dest+num) =*((char*)src+num); } } returnret; } intmain() { intarr1[10] = { 1,2,3,4,5,6,7,8 }; my_memmove(arr1+3, arr1, 12); inti=0; for (i=0; i<8; i++) { printf("%d ", arr1[i]); } return0; }