這幾天做一個(gè)程序,在遍歷一個(gè)100萬(wàn)個(gè)數(shù)據(jù)的LIST的時(shí)候非常非常慢,我把可能出現(xiàn)消耗時(shí)間都打印出來(lái)了,死活都找不到消耗時(shí)間的地方在什么地方。
創(chuàng)新互聯(lián)長(zhǎng)期為1000+客戶(hù)提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為遼陽(yáng)縣企業(yè)提供專(zhuān)業(yè)的網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站,遼陽(yáng)縣網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。
最后盯上了判斷size()等于一個(gè)值的地方,因?yàn)榫褪O逻@個(gè)地方了,就打上了時(shí)間,結(jié)果發(fā)現(xiàn)竟然就是此處。一個(gè)size方法竟然消耗了0.02秒。注釋掉后就一切正常了。最后的解決辦法只好我?guī)椭鼇?lái)計(jì)數(shù)。
寫(xiě)了個(gè)小程序,發(fā)現(xiàn)list的size果然消耗時(shí)間,不過(guò)幸運(yùn)的是empty不消耗時(shí)間。
而最幸運(yùn)的是最常用的map的size并不消耗時(shí)間。
有空看看源碼吧,難道每次size都要從頭計(jì)算一次嗎?
#include
#include
#include
using namespace std;
void p1()
{
struct timeval start;
gettimeofday(&start, 0);
printf("%u,%u\n",start.tv_sec,start.tv_usec);
}
int main()
{
list
p1();
for(int i=0;i<10000;i++)
lista.push_back(1);
p1();
for(int i=0;i<1000;i++)
{
lista.size();
lista.pop_front();
}
p1();
for(int i=0;i<1000;i++)
lista.pop_front();
p1();
return 0;
}
結(jié)果:
1238513193,693237
1238513193,695993
1238513193,795487
1238513193,795597
只是1W個(gè)數(shù)據(jù)就這樣慢的,100W的數(shù)據(jù)更是慢的驚人。
--------------------------------------------------------------------
查了一下源碼,果然是每次重新計(jì)算的,難道就為了節(jié)省4字節(jié)的空間?
size_type size() const {
size_type __result = 0;
distance(begin(), end(), __result);
return __result;
}