0️⃣memcpy
1️⃣函数声明
void * memcpy ( void * destination, const void * source, size_t num );
2️⃣函数功能
将source指针所指向的地址开始之后的num个字节的数据拷贝到destination所指向的地址的之后的num个字节中
3️⃣函数说明
(1)这个函数在遇到 '\0' 的时候并不会停下来。
(2)如果source和destination有任何的重叠,复制的结果都是未定义的
4️⃣函数的模拟实现
void* MyMemcpy(void* dest, const void* src, size_t num) { assert(dest); assert(src); void* ret = dest; for (int i = 0; i < num; i++) { *(char*)dest = *(char*)src; dest = (char*)dest + 1; src = (char*)src + 1; } return ret; }
0️⃣memmove
1️⃣函数声明
void * memmove ( void * destination, const void * source, size_t num );
2️⃣函数功能
将source指针所指向的地址开始之后的num个字节的数据拷贝到destination所指向的地址的之后的num个字节中(可以处理重叠的内存空间)
3️⃣函数说明
(1)如果原空间和目标空间存在重叠,如果要进行数据拷贝,则需要用memmove函数来进行
(2)为什么memmove函数可以实现重叠内存空间的数据拷贝呢?
因为memmove函数内部会对两个地址的大小进行判断进而采用不同的拷贝方式:
①destination > source的情况
memmove函数内部采用从source前面开始拷贝数据这样就不会覆盖数据了
②destinaion < source的情况
memmove函数内部采用从source后面向前拷贝数据;
4️⃣函数实现
void* MyMemmove(void* dest, const void* src, size_t num) { 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); } } return ret; }
0️⃣memcmp
1️⃣函数声明
int memcmp ( const void * ptr1,const void * ptr2,size_t num );
2️⃣函数功能
比较从ptr1和ptr2指针开始的num个字节
3️⃣函数说明
返回值类型为int 和strcmp是类似的
(1)如果无差异则返回零
(2)如果遇到第一个不相同的,则返回的是ptr1所指向的内存块所存储的数据减去ptr2中的数据
4️⃣函数示例:
/* memcmp example */ #include <stdio.h> #include <string.h> int main () { char buffer1[] = "DWgaOtP12df0"; char buffer2[] = "DWGAOTP12DF0"; int n; n=memcmp ( buffer1, buffer2, sizeof(buffer1) ); if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2); else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2); else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2); return 0; }