有時候採用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行,
而導致每次都內存。