memcpy的威力

有时候采用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行,

而导致每次都内存。



你可能感兴趣的:(优化,cache,buffer,360)