目录: 1.memcpy函数(内存拷贝)(1)memcpy函数的说明(2)memcpy的使用a.代码b.结果 (3)memcpy的模拟实现a.代码b.结果 2.memmove函数(1)memmove函数的说明(2)内存重叠问题a.分析b.代码说明 (3)内存重叠问题的解决分析(4)memmove的使用(5)模拟实现memmove
1.memcpy函数(内存拷贝) (1)memcpy函数的说明
• 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
• 这个函数在遇到 ‘ ’ 的时候并不会停下来。
• 如果source和destination有任何的重叠,复制的结果都是未定义的
注意:• memcpy函数有返回值
• void可以满足任意类型的指针
• 因为传进来的数据类型不确定,将传进来的数据强转为char,实现一个字节一个字节拷贝
• sizeof计算需要拷贝的字节数
• memmove也是内存拷贝,可以解决内存重叠问题
• 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
• 如果源空间和目标空间出现重叠,就得使用memmove函数处理。
即dst在src的内存范围之内就会出现重叠问题
a.分析 b.代码说明 #include<stdio.h>#include<string.h>int main(){int a[10] = { 1, 2, 3, 4, 5 };memcpy(a + 4, a, 20);return 0;} (3)内存重叠问题的解决分析如果不重叠:随便拷贝
(4)memmove的使用 #include<stdio.h>#include<string.h>int main(){int a[10] = { 1, 2, 3, 4, 5 };memmove(a + 4, a, 20);return 0;} (5)模拟实现memmove #include<stdio.h>#include<string.h>void* my_memmove(void* dst, const void* src, size_t num){char* ch_dst = (char*)dst;const char* ch_src = (const char*)src;//从后往前拷if (ch_dst >= src && ch_dst <= ch_src + num){for (int i = num - 1; i >= 0; --i){ch_dst[i] = ch_src[i];}}//从后往前拷else{for (int i = 0; i < num; ++i){ch_dst[i] = ch_src[i];}}return dst;}int main(){int a[10] = { 1, 2, 3, 4, 5 };my_memmove(a + 4, a, 20);return 0;}