1 memcpy
memcpy - 复制内存块
1.1 模拟实现memcpy
#include<assert.h>
void* my_memcpy(void* dest, const void* src, size_t num)
{
void* ret = dest;
assert(dest && src);
while (num--)
{
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
return ret;
}
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
my_memcpy(arr2, arr1, 20);
return 0;
}
为什么是char*?
因为void* 这种指针不能直接解引用和±运算。但是如果运用int-4字节,如果num = 7,显然int是不行的,char-一个字节,更为合适。
2memmove
memmove - 移动内存块
memcpy - 复制内存块
2.1memmove - 移动内存块与memcpy - 复制内存块区别
这个对于memcpy是不能实现的
我们使用menmove是没有问题的。
2.2模拟实现memmove
我们可以2和3从后向前,1从前向后。
void* my_memmove(void* dest, const void* src, size_t num)
{
void* ret = dest;
assert(dest && src);
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;
}
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
my_memmove(arr1+2, arr1, 20);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", arr1[i]);
}
return 0;
}
else
{
while (num--)
{
*((char*)dest + num) = *((char*)src + num);
}
}
假设num = 20
对于*((char*)dest + num)
当num-- 到*((char*)dest + num)
时num等于19,这样*((char*)dest + num)
就等于20,就完成了从后向前进行覆盖,然后num–,num变成18,以此类推。
3,memcmp
memcmp - 比较两个内存块