首先看一段代码
#include <stdio.h>
#include <pthread.h> int main(){ int t1[];
int i = ;
for(i; i<; i++)
{
t1[i] = i;
printf("t1[%d] = %d\n", i, t1[i]);
}
printf("\n"); memcpy(&t1[], &t1[], *sizeof(int)); i = ;
for(i; i<; i++)
{
printf("t1[%d] = %d\n", i, t1[i]);
}
return ;
}
我跑在ubuntu16.04, 输出的结果是:
t1[] =
t1[] =
t1[] =
t1[] =
t1[] =
但是同样的程序跑在ubuntu14.04的虚拟机上,运行的结果是:
t1[] =
t1[] =
t1[] =
t1[] =
t1[] =
mempcy 组内拷贝看起来是不安全的。需要进一步研究。
不同的公司对于stdlib function的实现不同,像这种内存重叠的拷贝需要使用api memmove(),而不是memcpy。
原理上,当内存重叠时,先将内容复制岛类似缓冲区的地方,再用缓冲区中的内容覆盖dest只想的内存。效率上会比memcpy慢。