有时候采用memcpy可以使程序的效率提高很多,有时候也会拖延程序的运行时间。对于c/c++内置类型建议不宜采用memcpy作为拷贝方式,可以直接操作其地址来达到赋值效果。比如将int 类型的数值拷贝到一段buffer当中,可以直接采用赋值方式
example:
uint8_t *buffer=new uint8_t[1024];int sendLength=100;*(int*)buffer=sendLength;
在下面这种情况memcpy这显示出威力:
#include<stdio.h>
#include<stdlib.h>
#include<memory.h>
#include<time.h>
#define DUMBCOPY for(unsigned int i=0;i<65535;i++) \
destination[i]=source[i];
#define MEMERYCOPY memcpy(destination,source,65535);
int _tmain(int argc, _TCHAR* argv[])
{
clock_t begin, end;
begin = clock();
char source[65536],destination[65536];
int j;
for(int j=0;j<6553600;j++);
DUMBCOPY //MEMERYCOPY
end = clock();
printf("time==%lf",double(end-begin));
return 0;
}
采用DUMCOPY的效率 比MEMERYCOPY效率要查一些,对于DUMCOPY 这个source和destination都使用同一cache行,会导致每次对内存的引用都无法命中,使CPU效率大大降低。
库函数memcpy经过特别的优化,它先读取一个cache行再对它进行写入,这时就不会出现使用同一cache行,
而导致每次都内存。