千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當前位置:首頁  >  技術(shù)干貨  > Phaser運行機制是什么樣的?

Phaser運行機制是什么樣的?

來源:千鋒教育
發(fā)布人:wjy
時間: 2022-09-14 16:58:42 1663145922

  Phaser運行機制是什么樣的

  Registration(注冊)

  跟其他barrier不同,在phaser上注冊的parties會隨著時間的變化而變化。任務(wù)可以隨時注冊(使用方法register,bulkRegister注冊,或者由構(gòu)造器確定初始parties),并且在任何抵達點可以隨意地撤銷注冊(方法arriveAndDeregister)。就像大多數(shù)基本的同步結(jié)構(gòu)一樣,注冊和撤銷只影響內(nèi)部count;不會創(chuàng)建更深的內(nèi)部記錄,所以任務(wù)不能查詢他們是否已經(jīng)注冊。(不過,可以通過繼承來實現(xiàn)類似的記錄)

  Synchronization(同步機制)

  和CyclicBarrier一樣,Phaser也可以重復(fù)await。方法arriveAndAwaitAdvance的效果類似CyclicBarrier.await。phaser的每一代都有一個相關(guān)的phase number,初始值為0,當所有注冊的任務(wù)都到達phaser時phase+1,到達最大值(Integer.MAX_VALUE)之后清零。使用phase number可以獨立控制 到達phaser 和 等待其他線程 的動作,通過下面兩種類型的方法:

  1. Arrival(到達機制) arrive和arriveAndDeregister方法記錄到達狀態(tài)。這些方法不會阻塞,但是會返回一個相關(guān)的arrival phase number;也就是說,phase number用來確定到達狀態(tài)。當所有任務(wù)都到達給定phase時,可以執(zhí)行一個可選的函數(shù),這個函數(shù)通過重寫onAdvance方法實現(xiàn),通常可以用來控制終止狀態(tài)。重寫此方法類似于為CyclicBarrier提供一個barrierAction,但比它更靈活。

  2. Waiting(等待機制) awaitAdvance方法需要一個表示arrival phase number的參數(shù),并且在phaser前進到與給定phase不同的phase時返回。和CyclicBarrier不同,即使等待線程已經(jīng)被中斷,awaitAdvance方法也會一直等待。中斷狀態(tài)和超時時間同樣可用,但是當任務(wù)等待中斷或超時后未改變phaser的狀態(tài)時會遭遇異常。如果有必要,在方法forceTermination之后可以執(zhí)行這些異常的相關(guān)的handler進行恢復(fù)操作,Phaser也可能被ForkJoinPool中的任務(wù)使用,這樣在其他任務(wù)阻塞等待一個phase時可以保證足夠的并行度來執(zhí)行任務(wù)。

  Termination(終止機制)

  可以用isTerminated方法檢查phaser的終止狀態(tài)。在終止時,所有同步方法立刻返回一個負值。在終止時嘗試注冊也沒有效果。當調(diào)用onAdvance返回true時Termination被觸發(fā)。當deregistration操作使已注冊的parties變?yōu)?時,onAdvance的默認實現(xiàn)就會返回true。也可以重寫onAdvance方法來定義終止動作。forceTermination方法也可以釋放等待線程并且允許它們終止。

  Tiering(分層結(jié)構(gòu))

  Phaser支持分層結(jié)構(gòu)(樹狀構(gòu)造)來減少競爭。注冊了大量parties的Phaser可能會因為同步競爭消耗很高的成本, 因此可以設(shè)置一些子Phaser來共享一個通用的parent。這樣的話即使每個操作消耗了更多的開銷,但是會提高整體吞吐量。

  在一個分層結(jié)構(gòu)的phaser里,子節(jié)點phaser的注冊和取消注冊都通過父節(jié)點管理。子節(jié)點phaser通過構(gòu)造或方法register、bulkRegister進行首次注冊時,在其父節(jié)點上注冊。子節(jié)點phaser通過調(diào)用arriveAndDeregister進行最后一次取消注冊時,也在其父節(jié)點上取消注冊。

  Monitoring(狀態(tài)監(jiān)控)

  由于同步方法可能只被已注冊的parties調(diào)用,所以phaser的當前狀態(tài)也可能被任何調(diào)用者監(jiān)控。在任何時候,可以通過getRegisteredParties獲取parties數(shù),其中g(shù)etArrivedParties方法返回已經(jīng)到達當前phase的parties數(shù)。當剩余的parties(通過方法getUnarrivedParties獲取)到達時,phase進入下一代。這些方法返回的值可能只表示短暫的狀態(tài),所以一般來說在同步結(jié)構(gòu)里并沒有啥卵用。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
怎樣投抖加不花錢?別人能看出來嗎?

抖音一些視頻為了獲取更多點擊,一些博主機會投抖加。其實抖加的投放沒有絕對正確的方法,而不同賬號和視頻投放的策略都是不一樣的,不過一般情...詳情>>

2023-09-19 08:00:10
抖店入駐收費多少?開抖店費用是多少?

如果要開通抖音小店,需要先把抖音賬號開通商品櫥窗功能。入駐之后,可以選擇頭條賬號、抖音賬號、火山賬號任一類型注冊或登錄。那開個抖店要多...詳情>>

2023-09-19 07:50:26
想做直播帶貨的貨源哪里來?怎么找貨源?

現(xiàn)如今直播推廣的方式是非?;鸬?,有著非常多的賣家都是利用直播推廣店鋪產(chǎn)品,效果也是非常不錯。但很多賣家想要了解現(xiàn)在直播帶貨的話什么產(chǎn)品...詳情>>

2023-09-19 07:47:16
適合三農(nóng)領(lǐng)域的名字?有何技巧?

現(xiàn)在在抖音上很多博主會選擇直播來賺取更多的流量以及利潤,直播間的東西也有很多讓消費者信任并且喜歡的,而且隨著越來越多人直播,很多農(nóng)產(chǎn)品...詳情>>

2023-09-19 07:06:05
抖店商品發(fā)布違規(guī)怎么申訴?有何規(guī)則?

抖店服務(wù)市場服務(wù)商發(fā)布違禁信息如何處理?情節(jié)嚴重程度判定原則:違規(guī)嚴重等級主要通過服務(wù)商違規(guī)次數(shù)、造成后果的嚴重程度、獲利或?qū)е聯(lián)p失的...詳情>>

2023-09-19 06:59:55
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)