基于C++執(zhí)行內(nèi)存memcpy效率測試的分析
在進(jìn)行memcpy操作時,雖然是內(nèi)存操作,但是仍然是耗一點點CPU的,今天測試了一下單線程中執(zhí)行memcpy的效率,這個結(jié)果對于配置TCP epoll中的work thread
數(shù)量有指導(dǎo)意義。如下基于8K的內(nèi)存快執(zhí)行memcpy, 1個線程大約1S能夠拷貝500M,如果服務(wù)器帶寬或網(wǎng)卡到上限是1G,那么網(wǎng)絡(luò)io的work thread 開2個即可,考慮到消息的解析損耗,3個線程足以抗住硬件的最高負(fù)載。
在我到測試機(jī)器上到測試結(jié)果是:
Intel(R) Xeon(R) CPU E5405 @ 2.00GHz
do memcpy speed:12.27 ms/MB
each thread can do memcpy 667.645 MB
#include <iostream>
#include <sys/time.h>
#include <string.h>
using namespace std;
int main(int argc, char* argv[])
{
long len = 8192;
int loop = 200;
char* p = new char[len];
char* q = p;
struct timeval start, end;
gettimeofday(&start, NULL);
for (int i =0; i < loop; ++i)
{
char* p = new char[len];
*p = char(i);
memcpy(p, q, len);
delete [] p;
}
gettimeofday(&end, NULL);
cout <<"do memcpy speed:" << ((end.tv_sec - start.tv_sec)*1000 + double(end.tv_usec - start.tv_usec) / (len*loop/1000/1000) ) / loop<<" ms/MB\n";
cout <<"each thread can do memcpy "<< double(len)*loop/1000/1000 / ((end.tv_sec - start.tv_sec) + double(end.tv_usec - start.tv_usec) / 1000/1000) <<" MB\n";
}
相關(guān)文章
C++ 數(shù)據(jù)結(jié)構(gòu)之kmp算法中的求Next()函數(shù)的算法
這篇文章主要介紹了C++ 數(shù)據(jù)結(jié)構(gòu)之kmp算法中的求Next()函數(shù)的算法的相關(guān)資料,需要的朋友可以參考下2017-06-06C++ COM編程之QueryInterface函數(shù)(一)
這篇文章主要介紹了C++ COM編程之QueryInterface函數(shù)(一),QueryInterface是組件本身提供對自己查詢的一個接口,需要的朋友可以參考下2014-10-10