C/C++ memcpy函数的用法

功能

memcpy指的是c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中

头文件

所在头文件 或< 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("%dnr",sizeof(b));
 7     printf("%sn",b);
 8     for(int i = 0; i < sizeof(b); i++)
 9         printf("b[%d]的字符串是%cnr",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]的值是%cn",b[0]);
 8     printf("b[0]的值是%cn",b[0]>>8);
 9     printf("b[1]的值是%xn",b[1]);
10     printf("b[2]的值是%xn",b[2]);
11     printf("b[3]的值是%xn",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]的值是%xnr",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]的值是%xnr",i,d[i]);
10     return 0;
11 }

运行结果

在这里插入图片描述
原文链接: https://www.cnblogs.com/ybqjymy/p/12372225.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/193635

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月12日 下午6:27
下一篇 2023年2月12日 下午6:27

相关推荐