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