前段時(shí)間看到園子里面有同學(xué)在用Parallel進(jìn)行批量插入數(shù)據(jù)庫。后面也有很多同學(xué)針對(duì)這一事件給出了自己的看法和見解。我在這里不評(píng)論內(nèi)容的好壞,至少能將自己東西總結(jié)分享這個(gè)是要靠勇氣和毅力。

     閑話少說,我在最近看崔鵬飛的github的時(shí)候,發(fā)現(xiàn)他對(duì)這塊也做了一定的總結(jié),那么我就他這塊進(jìn)行板書與展示。案例是怎么回事呢?話說我有一個(gè)公司,里面需要統(tǒng)計(jì)一下總收入,另外有一個(gè)公司被我收購了,我一起計(jì)算總收入。當(dāng)一天我收購了N個(gè)公司,計(jì)算總收入的時(shí)候,我們采用并行計(jì)算。

 View Code

首先我們想到的是采用直接累加就行了吧,這是所謂的線性預(yù)算。

采用線性運(yùn)算,毫無疑問結(jié)果是正確的。但是,如果的N大一點(diǎn),例如30000000個(gè),可能就要花一點(diǎn)時(shí)間了。

那么是否我們可以采用并行處理呢?OK,直接上代碼。

 View Code

時(shí)間很快,但是結(jié)果呢?結(jié)果和上面線性的一致么?

那么我如果在并行的基礎(chǔ)上面加一把鎖呢,保證每次獨(dú)占資源。