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行,

而導致每次都內存。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章