前段時間看到園子里面有同學(xué)在用Parallel進行批量插入數(shù)據(jù)庫。后面也有很多同學(xué)針對這一事件給出了自己的看法和見解。我在這里不評論內(nèi)容的好壞,至少能將自己東西總結(jié)分享這個是要靠勇氣和毅力。
閑話少說,我在最近看崔鵬飛的github的時候,發(fā)現(xiàn)他對這塊也做了一定的總結(jié),那么我就他這塊進行板書與展示。案例是怎么回事呢?話說我有一個公司,里面需要統(tǒng)計一下總收入,另外有一個公司被我收購了,我一起計算總收入。當一天我收購了N個公司,計算總收入的時候,我們采用并行計算。
View Code
首先我們想到的是采用直接累加就行了吧,這是所謂的線性預(yù)算。
采用線性運算,毫無疑問結(jié)果是正確的。但是,如果的N大一點,例如30000000個,可能就要花一點時間了。
那么是否我們可以采用并行處理呢?OK,直接上代碼。
View Code
時間很快,但是結(jié)果呢?結(jié)果和上面線性的一致么?
那么我如果在并行的基礎(chǔ)上面加一把鎖呢,保證每次獨占資源。