功能
memcpy指的是c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中
头文件
所在头文件 <string.h>或< cstring >
函数原型
_CRTIMP int __cdecl __MINGW_NOTHROW memcmp (const void*, const void*, size_t) __MINGW_ATTRIB_PURE;
参数含义:
- 第一个参数:目的地址
- 第二个参数:源地址
- 第三个参数:所需要复制的字节数
程序用例
- 目的地址与原地址数据宽度相同的时候
1 int main()
2 {
3 char a[4] = "mmmm";
4 char b[7] = "123455";
5 memcpy(b,a,3);
6 printf("%d\n\r",sizeof(b));
7 printf("%s\n",b);
8 for(int i = 0; i < sizeof(b); i++)
9 printf("b[%d]的字符串是%c\n\r",i,b[i]);
10 return 0;
11 }
运行结果
可以看出memcpy函数只复制需要size_t个字节数据到目的地址,目的地址size_t之后的数据并不会改变
- 目的地址的宽度比原地址不相等时
1 int main()
2 {
3 char a[8] = "abcdef";
4 short b[4] = {0x17,0x18,0x19,0x19};
5 //目的地址数据宽
6 memcpy(b,a,6);
7 printf("b[0]的值是%c\n",b[0]);
8 printf("b[0]的值是%c\n",b[0]>>8);
9 printf("b[1]的值是%x\n",b[1]);
10 printf("b[2]的值是%x\n",b[2]);
11 printf("b[3]的值是%x\n",b[3]);
12 return 0;
13 }
运行结果
可以看到原始数据先复制到低位,再复制到高位,感觉这个可能跟数据的存储大端小端有关系,在CCS上测试了也是这样的效果。
- 目的地址的宽度比原地址的宽度小
1 int main()
2 {
3 //源地址数据宽
4 short c[5] = {0x1234,0x5678,0x2345,0x3390};
5 char d[10] = {0};
6 memcpy(d,c,6);
7 for(int i = 0; i < sizeof(d); i++)
8 printf("d[%d]的值是%x\n\r",i,d[i]);
9 return 0;
10 }
运行结果
先复制的是低位,再复制的是高位。
-复制之后再还原
1 int main()
2 {
3 char a[8] = "abcdef";
4 short b[4] = {0x17,0x18,0x19,0x19};
5 memcpy(b,a,6);
6 char d[10] = {0};
7 memcpy(d,b,6);
8 for(int i = 0; i < sizeof(d); i++)
9 printf("d[%d]的值是%x\n\r",i,d[i]);
10 return 0;
11 }
运行结果
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)