• C语⾔内存函数


    1. memcpy使⽤和模拟实现

    void * memcpy ( void * destination, const void * source, size_t num );
    

    • 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。

    • 这个函数在遇到 '\0' 的时候并不会停下来。

    • 如果source和destination有任何的重叠,复制的结果都是未定义的。

    1. #include
    2. #include
    3. int main()
    4. {
    5. int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
    6. int arr2[10] = { 0 };
    7. memcpy(arr2, arr1, 20);
    8. int i = 0;
    9. for (i = 0; i < 10; i++)
    10. {
    11. printf("%d ", arr2[i]);
    12. }
    13. return 0;
    14. }

    memcpy函数的模拟实现:

    1. void * memcpy ( void * dst, const void * src, size_t count)
    2. {
    3. void * ret = dst;
    4. assert(dst);
    5. assert(src);
    6. /*
    7. * copy from lower addresses to higher addresses
    8. */
    9. while (count--) {
    10. *(char *)dst = *(char *)src;
    11. dst = (char *)dst + 1;
    12. src = (char *)src + 1;
    13. }
    14. return(ret);
    15. }

    2. memmove 使⽤和模拟实现

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

    • 和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。

    • 如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。

    1. #include
    2. #include
    3. int main()
    4. {
    5. int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
    6. memmove(arr1+2, arr1, 20);
    7. int i = 0;
    8. for (i = 0; i < 10; i++)
    9. {
    10. printf("%d ", arr2[i]);
    11. }
    12. return 0;
    13. }

    输出的结果:

    1 2 1 2 3 4 5 8 9 10

    memmove的模拟实现:

    1. void * memmove ( void * dst, const void * src, size_t count)
    2. {
    3. void * ret = dst;
    4. if (dst <= src || (char *)dst >= ((char *)src + count)) {
    5. /*
    6. * Non-Overlapping Buffers
    7. * copy from lower addresses to higher addresses
    8. */
    9. while (count--) {
    10. *(char *)dst = *(char *)src;
    11. dst = (char *)dst + 1;
    12. src = (char *)src + 1;
    13. }
    14. }
    15. else {
    16. /*
    17. * Overlapping Buffers
    18. * copy from higher addresses to lower addresses
    19. */
    20. dst = (char *)dst + count - 1;
    21. src = (char *)src + count - 1;
    22. while (count--) {
    23. *(char *)dst = *(char *)src;
    24. dst = (char *)dst - 1;
    25. src = (char *)src - 1;
    26. }
    27. }
    28. return(ret);
    29. }

    3. memset 函数的使⽤

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

    memset是⽤来设置内存的,将内存中的值以字节为单位设置成想要的内容。

    1. #include
    2. #include
    3. int main ()
    4. {
    5. char str[] = "hello world";
    6. memset (str,'x',6);
    7. printf(str);
    8. return 0;
    9. }

    输出的结果:

    xxxxxxworld

    4. memcmp 函数的使⽤

    int memcmp ( const void * ptr1, const void * ptr2, size_t num );
    1. #include
    2. #include
    3. int main()
    4. {
    5. char buffer1[] = "DWgaOtP12df0";
    6. char buffer2[] = "DWGAOTP12DF0";
    7. int n;
    8. n = memcmp(buffer1, buffer2, sizeof(buffer1));
    9. if (n > 0) printf("'%s' is greater than '%s'.\n", buffer1, buffer2);
    10. else if (n < 0) printf("'%s' is less than '%s'.\n", buffer1, buffer2);
    11. else printf("'%s' is the same as '%s'.\n", buffer1, buffer2);
    12. return 0;
    13. }

  • 相关阅读:
    mac系统占用内存太大怎么办?
    宇视摄像机实况画面不清晰排查方法
    若依微服务如何处理Long类型精度丢失问题?
    竞赛 基于大数据的时间序列股价预测分析与可视化 - lstm
    python使用pip命令安装出错:Could not fetch URL https://pypi.org/simple/selenium/
    羽夏看Linux内核——门相关入门知识
    跑通官方的yolov7-tiny实验记录(yolov7-tiny可作为yolov5s的对比实验网络)
    浅谈双指针技巧(三)利用快慢指针,查找链表中指定位置节点
    Spring Cloud——Nacos(注册中心快速入门、服务发现详解、集成openFeign和gateway)
    【多线程】synchronized的特性
  • 原文地址:https://blog.csdn.net/YishanWasten/article/details/134389157