目录
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;
}