商城系統(tǒng) 注冊

微信小程序開發(fā)多線程處理機制worker

2020-09-27|HiShop
導讀:摘要:在小程序中有線程并發(fā)執(zhí)行的階段,這時候worker可以處理小程序開發(fā)的多線程機制。 不少從事開發(fā)崗的技術(shù)人員都了解過多線程問題,多線程是指從軟件或者硬件上實現(xiàn)多個線程...
摘要:在微信小程序中有線程并發(fā)執(zhí)行的階段,這時候worker可以處理開發(fā)小程序的多線程機制。
 

不少從事搭建崗的技術(shù)人員都了解過多線程問題,多線程是指從系統(tǒng)或者硬件上實現(xiàn)多個線程并發(fā)執(zhí)行的技術(shù)。具有多線程能力的計算機因有硬件支持而能夠在同一時間執(zhí)行多于一個線程,進而提升整體處理性能。在微信小程序中也可能有線程并發(fā)執(zhí)行的階段,這時候worker可以處理開發(fā)小程序的多線程機制。

微信小程序的一些異步處理任務可放置worker中運行,原理是調(diào)用worker執(zhí)行多條并行線程,待結(jié)果返回到微信小程序的主線程。當操作worker時,主線程數(shù)據(jù)被復制并通過 Worker.Message()來傳輸,其中 Worker.postMessage()是發(fā)送數(shù)據(jù)函數(shù),Worker.onMessage()則是接收。

 

操作worker首先要配置worker信息,在app.js中聲明worker放置目錄,目錄下的代碼將被打包成一個文件:

{

workers: workers

}

接著在worker中添加文件,添加一個請求文件夾request和一個相應文件夾response。

workers/request/index.js

workers/request/utils.js

workers/response/index.js

微信小程序開發(fā)多線程處理機制worker

添加后,目錄結(jié)構(gòu)如下:

├── app.js

├── app.json

├── project.config.json

└── workers

├── request

│   ├── index.js

│   └── utils.js

└── response

└── index.js

下一步編寫 Worker 代碼

在workers/request/index.js編寫 Worker 響應代碼

var utils = require(\'./utils\')

// 在 Worker 線程執(zhí)行上下文會全局設立一個 `worker` 對象,直接調(diào)用

worker.onMeesage/postMessage 即可

worker.onMessage(function (res) {

console.log(res)

})

接著在主線程中初始化Worker

在主線程的代碼 app.js 中聲明 Worker

var worker = wx.createWorker(\'workers/request/index.js\') // 文件名指定 worker

的入口文件路徑,絕對路徑

最后主線程向Worker發(fā)出數(shù)據(jù)接收請求

worker.postMessage({

msg: \'hello worker\'

})

操作worker注意事項:

Workers 之間不支持發(fā)送消息。

Worker 的入??谖募?wx.createWorker() 時指定,搭建者可動態(tài)指定 Worker 入口文件

Worker 內(nèi)代碼只能 require 指定 Worker 路徑內(nèi)的文件,無法引用其它路徑。

Worker 最大并發(fā)數(shù)量束縛為 1 個,設立下一個前請用 Worker.terminate() 結(jié)束當前 Worker。

Worker 內(nèi)不支持 wx 系列的 API。

 

推薦閱讀:微信小程序前端搭建群功能教材    微信小程序搭建教材


電話咨詢 預約演示 0元開店