news 2026/6/10 17:16:21

C语言内存函数介绍和模拟实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言内存函数介绍和模拟实现

当我们超越字符串的边界,进入更底层的领域,便会遇见直接操作内存的工具——mem系列函数。它们不关心数据是字符、数字还是结构体,仅以原始的字节视角高效处理内存块。无论是大块数据的快速复制(memcpy)、重叠区域的稳妥搬运(memmove),还是内存的批量初始化(memset)与精确比较(memcmp),这些函数都是系统编程、算法实现和性能优化的基石。掌握它们,意味着你真正开始以计算机的方式“思考”数据在内存中的流动与组织。

目录

1.memcpy函数使用和模拟实现

2.memmove函数使用和模拟实现

3.memset函数使用和模拟实现

4.memcmp函数使用和模拟实现


1.memcpy函数使用和模拟实现

函数原型:

void* memcpy(void* destination, const void* source, size_t num);
  • destination:目标内存起始地址(接收拷贝数据)

  • source:源内存起始地址(提供拷贝数据)

  • num:要拷贝的字节数(核心:不是元素数!)

作用:将一段内存的二进制数据 “原样拷贝” 到另一段内存

函数遇到'\0' 的时候并不会停下来,不处理内存重叠,重叠会导致数据错误,拷贝字符串时,不会自动添加'\0'

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

模拟实现:

void* my_memcpy(void* destination, const void* source, size_t num) { assert(destination); assert(source); void* ret = destination; while (num) { *(char*)destination = *(char*)source; destination = (char*)destination + 1; source = (char*)source + 1; num--; } return ret; } int main() { int arr1[20] = { 0 }; int arr2[] = { 1,2,3,4,5,6,7,8,9,10 }; my_memcpy(arr1, arr2, 12); int i = 0; for (i = 0; i < 20; i++) { printf("%d ", arr1[i]); } return 0; }

2.memmove函数使用和模拟实现

函数原型:

void* memmove(void* destination, const void* source, size_t num);
  • destination:目标内存起始地址(接收拷贝数据)

  • source:源内存起始地址(提供拷贝数据)

  • num:要拷贝的字节数(核心:不是元素数!)

作用:支持内存重叠的通用内存拷贝函数,核心是在memcpy基础上解决了源内存和目标内存重叠时拷贝数据错误的问题。

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

模拟实现:

void* my_memmove(void* destination, const void* source, size_t num) { assert(destination); assert(source); void* pcur = destination; char* p = (char*)destination; char* q = (char*)source; if (p < q) { while (num--) { *p++ = *q++; } } else { p += num - 1; q += num - 1; while (num--) { *p-- = *q--; } } return pcur; } int main() { int arr[10] = { 1,2,3,4,5,6,7,8,9,10 }; my_memmove(arr+2, arr, 20); int i = 0; for (i = 0; i < 10; i++) { printf("%d ", arr[i]); } return 0; }

3.memset函数使用和模拟实现

函数原型:

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

作用:memset 逐字节初始化内存,将指定内存区域的每一个字节统一设置为同一个单字节值。

int main() { char str[] = "hello world"; memset(str, 'x', 6); printf(str); //xxxxxxworld return 0; }

模拟实现:

void* my_memset(void* ptr, int value, size_t num) { assert(ptr != NULL); void* start_ptr = ptr; char fill_byte = (char)value; char* byte_ptr = (char*)ptr; while (num--) { *byte_ptr = fill_byte; byte_ptr++; } return start_ptr; } int main() { char str[20]; my_memset(str, 'a', 5); str[5] = '\0'; printf("char数组初始化:%s\n", str); // aaaaa return 0; }

4.memcmp函数使用和模拟实现

函数原型:

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

作用:从内存起始地址开始,按字节的二进制值逐位对比,直到发现首个不同字节完成num字节的比较;若ptr1对应字节的二进制值小于ptr2,返回负数;若两段内存前num个字节完全相等,返回 0;若ptr1对应字节大于ptr2,返回正数(返回值为首个不同字节的差值)

int main() { char buffer1[] = "DWgaOtP12df0"; char buffer2[] = "DWGAOTP12DF0"; int n; n = memcmp(buffer1, buffer2, sizeof(buffer1)); if (n > 0) printf("'%s' is greater than '%s'.\n", buffer1, buffer2); else if (n < 0) printf("'%s' is less than '%s'.\n", buffer1, buffer2); else printf("'%s' is the same as '%s'.\n", buffer1, buffer2); //'DWgaOtP12df0' is greater than 'DWGAOTP12DF0'. return 0; }

模拟实现:

int my_memcmp(const void* ptr1, const void* ptr2, size_t num) { assert(ptr1 != NULL && ptr2 != NULL); const char* p1 = (const char*)ptr1; const char* p2 = (const char*)ptr2; while (num--) { if (*p1 != *p2) { return (char)*p1 - (char)*p2; } p1++; p2++; } return 0; } int main() { char str1[] = "abcde"; char str2[] = "abxde"; int ret1 = my_memcmp(str1, str2, 5); printf("%d\n", ret1); // 'c'(99)-'x'(120)=-21 int arr1[] = { 1, 2, 3 }; // 小端存储:01 00 00 00 | 02 00 00 00 | 03 00 00 00 int arr2[] = { 1, 4, 3 }; // 小端存储:01 00 00 00 | 04 00 00 00 | 03 00 00 00 int ret2 = my_memcmp(arr1, arr2, sizeof(arr1)); printf("%d\n", ret2); // 02-04=-2 return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/7 13:02:09

原神帧率解锁技术:突破60FPS限制的专业解决方案

原神帧率解锁技术&#xff1a;突破60FPS限制的专业解决方案 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 在现代游戏体验中&#xff0c;帧率限制往往成为硬件性能发挥的瓶颈。genshin-…

作者头像 李华
网站建设 2026/6/10 14:31:40

ComfyUI插件管理终极解决方案:告别混乱,实现300%效率提升

ComfyUI插件管理终极解决方案&#xff1a;告别混乱&#xff0c;实现300%效率提升 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager 你是否曾经在ComfyUI的插件海洋中迷失方向&#xff1f;安装一个节点却导致整个工作流崩…

作者头像 李华
网站建设 2026/6/9 15:39:46

深蓝词库转换:输入法词库格式不兼容的终极解决方案

深蓝词库转换&#xff1a;输入法词库格式不兼容的终极解决方案 【免费下载链接】imewlconverter ”深蓝词库转换“ 一款开源免费的输入法词库转换程序 项目地址: https://gitcode.com/gh_mirrors/im/imewlconverter 还在为不同输入法之间的词库无法通用而烦恼吗&#xf…

作者头像 李华
网站建设 2026/6/6 4:40:59

如何用genshin-fps-unlock突破游戏帧率限制?完整操作指南

如何用genshin-fps-unlock突破游戏帧率限制&#xff1f;完整操作指南 【免费下载链接】genshin-fps-unlock unlocks the 60 fps cap 项目地址: https://gitcode.com/gh_mirrors/ge/genshin-fps-unlock 您是否在热门游戏中感受到画面卡顿&#xff0c;操作响应不够灵敏&am…

作者头像 李华
网站建设 2026/6/10 14:16:37

零门槛视频硬字幕提取实战:本地OCR技术让你轻松搞定多语言字幕

还在为视频中的硬字幕无法复制而烦恼吗&#xff1f;想要收藏精彩台词却只能手动记录&#xff1f;今天我们就来聊聊如何用video-subtitle-extractor这个神器&#xff0c;在本地环境中轻松提取视频硬字幕&#xff0c;无需联网、不依赖第三方API&#xff0c;真正做到数据安全可控。…

作者头像 李华
网站建设 2026/6/10 14:17:56

XHS-Downloader技术深度解析:多模式架构与智能反爬策略

小红书作为国内领先的生活方式分享平台&#xff0c;其内容采集一直面临技术挑战。XHS-Downloader作为一款开源的小红书作品采集工具&#xff0c;通过创新的多模式架构设计&#xff0c;成功应对了平台的技术防护机制。本文将从技术实现层面&#xff0c;深度剖析该项目的核心架构…

作者头像 李华