91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

tunny中workerWrapper的作用是什么

發布時間:2021-06-22 17:34:17 來源:億速云 閱讀:163 作者:Leah 欄目:編程語言

本篇文章為大家展示了tunny中workerWrapper的作用是什么,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

workerWrapper

type workerWrapper struct {
	worker        Worker
	interruptChan chan struct{}

	// reqChan is NOT owned by this type, it is used to send requests for work.
	reqChan chan<- workRequest

	// closeChan can be closed in order to cleanly shutdown this worker.
	closeChan chan struct{}

	// closedChan is closed by the run() goroutine when it exits.
	closedChan chan struct{}
}

func newWorkerWrapper(
	reqChan chan<- workRequest,
	worker Worker,
) *workerWrapper {
	w := workerWrapper{
		worker:        worker,
		interruptChan: make(chan struct{}),
		reqChan:       reqChan,
		closeChan:     make(chan struct{}),
		closedChan:    make(chan struct{}),
	}

	go w.run()

	return &w
}

workerWrapper包裝了worker,定義了interruptChan、reqChan、closeChan、closedChan屬性

interrupt

func (w *workerWrapper) interrupt() {
	close(w.interruptChan)
	w.worker.Interrupt()
}

interrupt方法關閉w.interruptChan,執行w.worker.Interrupt()

run

func (w *workerWrapper) run() {
	jobChan, retChan := make(chan interface{}), make(chan interface{})
	defer func() {
		w.worker.Terminate()
		close(retChan)
		close(w.closedChan)
	}()

	for {
		// NOTE: Blocking here will prevent the worker from closing down.
		w.worker.BlockUntilReady()
		select {
		case w.reqChan <- workRequest{
			jobChan:       jobChan,
			retChan:       retChan,
			interruptFunc: w.interrupt,
		}:
			select {
			case payload := <-jobChan:
				result := w.worker.Process(payload)
				select {
				case retChan <- result:
				case <-w.interruptChan:
					w.interruptChan = make(chan struct{})
				}
			case _, _ = <-w.interruptChan:
				w.interruptChan = make(chan struct{})
			}
		case <-w.closeChan:
			return
		}
	}
}

run首先創建jobChan、retChan,然后for循環執行select讀取reqChan,之后讀取jobChan的payload,進行處理,然后寫入到retChan

stop

func (w *workerWrapper) stop() {
	close(w.closeChan)
}

stop方法關閉w.closeChan

join

func (w *workerWrapper) join() {
	<-w.closedChan
}

join方法則等待w.closedChan

小結

tunny的workerWrapper包裝了worker,定義了interruptChan、reqChan、closeChan、closedChan屬性,它提供了interrupt、run、stop、join方法。

上述內容就是tunny中workerWrapper的作用是什么,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

拜泉县| 冀州市| 高阳县| 利津县| 秦安县| 浑源县| 杂多县| 韩城市| 和平区| 鹤庆县| 扬州市| 聂拉木县| 正安县| 钟山县| 永吉县| 柏乡县| 江陵县| 丁青县| 体育| 竹山县| 黎平县| 句容市| 绥宁县| 邵东县| 林周县| 麻栗坡县| 平利县| 锡林浩特市| 诏安县| 颍上县| 阜阳市| 遂宁市| 桂东县| 梨树县| 贡山| 榕江县| 宝应县| 奎屯市| 略阳县| 古田县| 沧州市|