当前位置:   article > 正文

C语言内存函数(memcpy及memove的了解与使用)

C语言内存函数(memcpy及memove的了解与使用)

前言:

        前边我们了解了一些字符函数的使用以及它是如何实现的,但是我们会发现这些函数只可以针对字符串使用,对于其它类型的数据我们将无法使用这个函数的功能,那么我们今天就带着兄弟们了解一下何为内存函数,内存函数又可以实现哪些功能,它针对的类型又是什么

内存函数:

1. memcpy使⽤和模拟实现

2. memmove使⽤和模拟实现

3. memset函数的使⽤

4. memcmp函数的使⽤

1. memcpy函数:

1. 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置
2. 这个函数在遇到 '\0' 的时候并不会停下来
3. 如果source和destination有任何的重叠,复制的结果都是未定义的

语法:

void * memcpy ( void * destination, const void * source, size_t num );
(注意:此处的num代表的是num个字节数,并非一个元素)

举例:

  1. int main()
  2. {
  3. int arr[] = { 1,2,3,4,5,6,7,8,9,0 };
  4. int arr1[20] = { 0 };
  5. memcpy(arr1, arr, 16);
  6. //此处的16代表着16个字节,而我们访问的数组是int型,所以此处拷贝的是4个元素
  7. for (int i = 0; i < 20; i++)
  8. {
  9. printf("%d ", arr1[i]);
  10. }
  11. }
  12. //执行结果为
  13. 1 2 3 4 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

memcpy的模拟实现():

  1. memcpy函数模拟实现
  2. #include <assert.h> //assert函数的头文件
  3. //由于们memcpy函数是可以实现多种数据的拷贝,所以此处传入时指针的类型为void* ,方便后续强制转换
  4. void* in_memcpy(void* destination, const void* source, size_t num)
  5. {
  6. void* ret = destination;
  7. assert(destination && source); //判断传入的两个指针是否为空
  8. while (num--)
  9. {
  10. *(char*)destination = *(char*)source; //逐字节交换
  11. ((char*)destination)++;
  12. ((char*)source)++;
  13. }
  14. return ret; //返回值
  15. }
  16. int main()
  17. {
  18. int arr[] = { 1,2,3,4,5,6,7,8,9,0 };
  19. int arr1[20] = { 0 };
  20. void* ret = in_memcpy(arr1, arr, 16); //16为字节数
  21. for (int i = 0; i < 20; i++)
  22. {
  23. printf("%d ", arr1[i]);
  24. }
  25. return 0;
  26. }

2. memove函数:

1. 和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的
2. 如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理

语法:

void * memmove ( void * destination, const void * source, size_t num );
举例:

  1. #include <string.h>
  2. int main()
  3. {
  4. int arr[] = { 1,2,3,4,5,6,7,8,9,0 };
  5. int arr1[20] = { 0 };
  6. //3开始拷贝三个元素到1往后三个元素的位置
  7. memmove(arr, arr+2, 12); //12表示12个字节数 此处等于3个int元素
  8. for (int i = 0; i < 10; i++)
  9. {
  10. printf("%d ", arr[i]);
  11. }
  12. }

memmove函数的模拟实现:

  1. #include <stdio.h>
  2. #include <assert.h>
  3. #include <string.h>
  4. void* in_memove(void* destination, const void* source, size_t num)
  5. {
  6. void* ret = destination;
  7. assert(destination && source);
  8. //此处判断满足条件从前面拷贝,不满足从后边拷贝
  9. if (destination <= source || (char*)destination >= (char*)source + num)
  10. {
  11. while (num--)
  12. {
  13. *(char*)destination = *(char*)source;
  14. ((char*)destination)++;
  15. ((char*)source)++;
  16. }
  17. }
  18. else
  19. {
  20. destination = (char*)destination + num - 1;
  21. source = (char*)source + num - 1;
  22. while (num--)
  23. {
  24. *(char*)destination = *(char*)source;
  25. ((char*)destination)--;
  26. ((char*)source)--;
  27. }
  28. }
  29. return ret;
  30. }
  31. int main()
  32. {
  33. int arr[] = { 1,2,3,4,5,6,7,8,9,0 };
  34. int arr1[20] = { 0 };
  35. void* ret = in_memove(arr, arr+2, 12);
  36. for (int i = 0; i < 10; i++)
  37. {
  38. printf("%d ", arr[i]);
  39. }
  40. }
  41. //执行结果
  42. 3 4 5 4 5 6 7 8 9 0

3. memset函数

memset函数将内存中以字节为单位你想要设置的值设置为你想要的内容

语法:

void * memset ( void * ptr, int value, size_t num );

举例:

  1. #include <string.h>
  2. int main()
  3. {
  4. char arr[] = "L love china";
  5. memset(arr, 'x', 5);
  6. for (int i = 0; i < 10; i++)
  7. {
  8. printf("%c", arr[i]);
  9. }
  10. }
  11. //执行结果
  12. xxxxxe china

4. memcmp函数:

语法:

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

⽐较从ptr1和ptr2指针指向的位置开始,向后的num个字节

(注:此处是逐字节比较,大于返回>0的数,小于返回<0的数,等于则=0)

举例:

  1. #include <string.h>
  2. int main()
  3. {
  4. char arr[] = "abcdf";
  5. char arr1[] = "abced";
  6. int ret = memcmp(arr, arr1, 4);
  7. printf("%d\n", ret);
  8. }
  9. //执行结果(此时arr<arr1,所以返回小于0的数)
  10. vs2022返回-1

(今日分享到此结束,有啥高见欢迎评论区留言,Thanks♪(・ω・)ノ!!!)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/325131?site
推荐阅读
相关标签
  

闽ICP备14008679号