DECO——被修飾的并發(fā)

使用DECO就像在Python編程中查找或者創(chuàng)建兩個(gè)函數(shù)一樣簡(jiǎn)便烁兰。第一個(gè)函數(shù)是我們想要并行運(yùn)行的函數(shù)疾掰,該函數(shù)使用@concurrent修飾一忱。第二個(gè)函數(shù)調(diào)用使用@concurrent修飾的函數(shù)共缕,并且使用@synchronized修飾自己洗出。修飾第二個(gè)函數(shù)是可選的,但是卻提供了非惩脊龋酷的益處翩活。讓我們看個(gè)例子:

@concurrent?#?We?add?this?for?the?concurrent?function

def?process_lat_lon(lat,?lon,?data):

? ? #Does?some?work?which?takes?a?while

? ? return?result

@synchronized?#?And?we?add?this?for?the?function?which?calls?the?concurrent?function

def?process_data_set(data):

? ? results?=?defaultdict(dict)

? ? for?lat?in?range(...):

? ? ? ? for?lon?in?range(...):

? ? ? ? ? ? results[lat][lon]?=?process_lat_lon(lat,?lon,?data)

? ? return?results

這就是要做的事情,我們只需要改動(dòng)兩行代碼就能使程序并行化蜓萄。此刻隅茎,程序?qū)⒊浞掷盟跈C(jī)器上所有CPU核,這使得程序飛速運(yùn)行嫉沽。

局限

@concurrent修飾器僅僅是加速運(yùn)行時(shí)間多于約1ms的那些函數(shù)

如果函數(shù)運(yùn)行時(shí)間少于1ms辟犀,你的代碼反而會(huì)運(yùn)行的更慢

@synchronized修飾器僅僅能在“簡(jiǎn)單”函數(shù)上起作用,確信你的函數(shù)滿足下面的標(biāo)準(zhǔn):

僅是調(diào)用或者賦值@concurrent函數(shù)的結(jié)果到索引的對(duì)象绸硕,就像下面的形式:

concurrent(...)

result[key] = concurrent(…)

不要間接的讀取被@concurrent函數(shù)調(diào)用而賦值的對(duì)象

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末堂竟,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子玻佩,更是在濱河造成了極大的恐慌出嘹,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咬崔,死亡現(xiàn)場(chǎng)離奇詭異税稼,居然都是意外死亡烦秩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門郎仆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)只祠,“玉大人,你說(shuō)我怎么就攤上這事扰肌∨浊蓿” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵曙旭,是天一觀的道長(zhǎng)盗舰。 經(jīng)常有香客問我,道長(zhǎng)桂躏,這世上最難降的妖魔是什么钻趋? 我笑而不...
    開封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮沼头,結(jié)果婚禮上爷绘,老公的妹妹穿的比我還像新娘。我一直安慰自己进倍,他們只是感情好土至,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著猾昆,像睡著了一般陶因。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上垂蜗,一...
    開封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天楷扬,我揣著相機(jī)與錄音,去河邊找鬼贴见。 笑死烘苹,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的片部。 我是一名探鬼主播镣衡,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼档悠!你這毒婦竟也來(lái)了廊鸥?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤辖所,失蹤者是張志新(化名)和其女友劉穎惰说,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缘回,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡吆视,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年典挑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片啦吧。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡搔弄,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出丰滑,到底是詐尸還是另有隱情,我是刑警寧澤倒庵,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布褒墨,位于F島的核電站,受9級(jí)特大地震影響擎宝,放射性物質(zhì)發(fā)生泄漏郁妈。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一绍申、第九天 我趴在偏房一處隱蔽的房頂上張望噩咪。 院中可真熱鬧,春花似錦极阅、人聲如沸胃碾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)仆百。三九已至,卻和暖如春奔脐,著一層夾襖步出監(jiān)牢的瞬間俄周,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工髓迎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留峦朗,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓排龄,卻偏偏與公主長(zhǎng)得像波势,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子涣雕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容