本文主要记录memcpy函数的用法,便于记住函数的过程。
codeblock平台
memcpy指的是c和c++使用的内存拷贝函数,memcpy函数的功能是从源src所指的内存地址的起始位置开始拷贝n个字节到目标dest所指的内存地址的起始位置中
所在头文件
_CRTIMP int __cdecl __MINGW_NOTHROW memcmp (const void*, const void*, size_t) __MINGW_ATTRIB_PURE;
参数含义:
int main()
{
char a[4] = "mmmm";
char b[7] = "123455";
memcpy(b,a,3);
printf("%d\n\r",sizeof(b));
printf("%s\n",b);
for(int i = 0; i < sizeof(b); i++)
printf("b[%d]的字符串是%c\n\r",i,b[i]);
return 0;
}
运行结果
可以看出memcpy函数只复制需要size_t个字节数据到目的地址,目的地址size_t之后的数据并不会改变
int main()
{
char a[8] = "abcdef";
short b[4] = {0x17,0x18,0x19,0x19};
//目的地址数据宽
memcpy(b,a,6);
printf("b[0]的值是%c\n",b[0]);
printf("b[0]的值是%c\n",b[0]>>8);
printf("b[1]的值是%x\n",b[1]);
printf("b[2]的值是%x\n",b[2]);
printf("b[3]的值是%x\n",b[3]);
return 0;
}
运行结果
可以看到原始数据先复制到低位,再复制到高位,感觉这个可能跟数据的存储大端小端有关系,在CCS上测试了也是这样的效果。
int main()
{
//源地址数据宽
short c[5] = {0x1234,0x5678,0x2345,0x3390};
char d[10] = {0};
memcpy(d,c,6);
for(int i = 0; i < sizeof(d); i++)
printf("d[%d]的值是%x\n\r",i,d[i]);
return 0;
}
运行结果
先复制的是低位,再复制的是高位。
-复制之后再还原
int main()
{
char a[8] = "abcdef";
short b[4] = {0x17,0x18,0x19,0x19};
memcpy(b,a,6);
char d[10] = {0};
memcpy(d,b,6);
for(int i = 0; i < sizeof(d); i++)
printf("d[%d]的值是%x\n\r",i,d[i]);
return 0;
}
运行结果
可以看到有比较好的还原过程
这些就是memcpy的实用过程,
以后要开始写博客了,感觉好多知识都忘记了,难受!!!