文章目录
- 一、函数简介
- 1、memcpy
- 2、memmove
- 二、代码实现
- 1、memcpy
- 2、memmove
- 三、小结
一、函数简介
1、memcpy
void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置,这个函数在遇到 ‘’ 的时候并不会停下来,如果source和destination有任何的重叠,复制的结果都是未定义的。
2、memmove
void * memmove ( void * destination, const void * source, size_t num );
memmove和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的,如果源空间和目标空间出现重叠,就得使用memmove函数处理。
二、代码实现
1、memcpy
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32void* my_memcpy(void* dest,const void* src,size_t count) { assert(dest && src); void* ret = dest; while(count--) { *(char*)dest = *(char*)src; dest = (char*)dest + 1; src = (char*)src + 1; } return ret; } int main() { /*char arr1[30] = "Hello "; char arr2[] = "Worldxxxxx";*/ int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 }; int arr2[5] = { 0 }; int sz = sizeof(arr2) / sizeof(arr2[0]); my_memcpy(arr2,arr1,20); int i = 0; for (i = 0; i < sz; i++) { printf("%d ", arr2[i]); } //printf("%sn",arr1); return 0; }
实现效果
2、memmove
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40void my_memmove(void* dest,const void* src,size_t count) { assert(dest && src); void* ret = dest; if (dest < src) { //从前往后拷贝 while (count--) { *(char*)dest = *(char*)src; dest = (char*)dest + 1; src = (char*)src + 1; } } else { //从后往前拷贝 while (count--) { *((char*)dest + count) = *((char*)src + count); } } return ret; } int main() { int arr[] = { 1,2,3,4,5,6,7,8,9,10 }; my_memmove(arr+2,arr,20); int sz = sizeof(arr) / sizeof(arr[0]); int i = 0; for (i = 0; i < sz; i++) { printf("%d ", arr[i]); } return 0; }
实现效果
三、小结
因为memcpy和memmove是对内存进行操作的,所以memcpy和memmove还可以实现其他数据类型的拷贝,例如字符、浮点型、结构体等等,函数的调用方法也是一样所以不过多演示。
最后
以上就是迷路小猫咪最近收集整理的关于模拟实现memcpy和memmove函数一、函数简介二、代码实现三、小结的全部内容,更多相关模拟实现memcpy和memmove函数一、函数简介二、代码实现三、小结内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复