日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

從簡單中窺見高端,徹底搞懂任務可中斷機制與任務插隊機制

來源: 責編: 時間:2024-05-11 09:15:51 213觀看
導讀今天我就用最基礎的方式重新跟大家分享一下什么是任務可中斷。一、任務拆分首先,我們要明確的一個前提,是一個完整的函數執行是不可以中斷的。因此如果你把一整個任務全部都放到一個函數中來執行,那么想要做到任務可中斷

0t628資訊網——每日最新資訊28at.com

今天我就用最基礎的方式重新跟大家分享一下什么是任務可中斷。0t628資訊網——每日最新資訊28at.com

一、任務拆分

首先,我們要明確的一個前提,是一個完整的函數執行是不可以中斷的。因此如果你把一整個任務全部都放到一個函數中來執行,那么想要做到任務可中斷是不可能的。0t628資訊網——每日最新資訊28at.com

例如,現在我有一個任務,往父級元素中插入 10 萬個子節點 <span>1</span>,然后我們可以隨便寫這樣一個函數來完成這個邏輯。0t628資訊網——每日最新資訊28at.com

btn.onclick = () => {  let i = 0  for (; i < 100000; i++) {    let span = document.createElement('span')    span.innerText = 1    container.appendChild(span)  }}

然后這個時候,我們就發現一個問題,當我們點擊之后,頁面上并不會立即顯示插入的內容,而是會卡頓一會兒,才會顯示。0t628資訊網——每日最新資訊28at.com

0t628資訊網——每日最新資訊28at.com

原因是因為 10 萬個節點的插入邏輯是一個同步的過程,JS 邏輯的執行時間過長導致了瀏覽器遲遲無法執行渲染。0t628資訊網——每日最新資訊28at.com

那么為了優化這種情況,我們可以考慮將渲染 10 萬個節點這個大的任務,拆分成 10 萬個渲染 1 個節點的小任務。0t628資訊網——每日最新資訊28at.com

function task() {  let span = document.createElement('span')  span.innerText = 1  container.appendChild(span)}

并將這 10 萬個任務,放進一個數組中。0t628資訊網——每日最新資訊28at.com

const taskQueue = Array.from({ length: 100000 }, () => task)

執行這 100 萬個任務,就通過遍歷 taskQueue 的方式來執行,這樣,我們就可以通過中斷隊列遍歷的方式,來中斷任務的執行。0t628資訊網——每日最新資訊28at.com

二、需要中斷的原因

在瀏覽器中,渲染引擎在每一幀都有機會渲染頁面,那么頁面的表現就不會卡頓。但是剛才我們的情況是,JS 執行時間過長,導致渲染引擎一直沒有機會渲染,所以用戶感受到的就是卡頓。0t628資訊網——每日最新資訊28at.com

那么解決這個問題的原理,就是根據瀏覽器渲染頻率,對 JS 要執行的任務進行拆分,JS 執行一部分,然后渲染引擎渲染一部分,完成之后,JS 再繼續執行,渲染引擎再渲染。0t628資訊網——每日最新資訊28at.com

通過這樣間隔執行的方式,讓用戶感知不到卡頓的存在。0t628資訊網——每日最新資訊28at.com

0t628資訊網——每日最新資訊28at.com

此時我們為了更好的觀察效果,讓每一個小任務的執行都阻塞 1ms。0t628資訊網——每日最新資訊28at.com

function task() {  const startTime = performance.now()  let span = document.createElement('span')  span.innerText = 1  while (performance.now() - startTime < 1) {    // 阻塞 1 ms  }  container.appendChild(span)}

然后把任務數量改成 1000。0t628資訊網——每日最新資訊28at.com

const taskQueue = Array.from({ length: 1000 }, () => task)

執行效果如下:0t628資訊網——每日最新資訊28at.com

0t628資訊網——每日最新資訊28at.com

五、插隊

我們另外起一個按鈕,專門用于執行一些插隊任務。插隊的邏輯非常簡單,只需要往 taskQueue 中添加任務即可。不過插隊任務的優先級更高一些,因此要通過 push 來添加,以確保任務能夠更早的執行。0t628資訊網——每日最新資訊28at.com

首先聲明一個 highPriorityTask 函數用于創建優先級更高的任務。0t628資訊網——每日最新資訊28at.com

function highPriorityTask() {  const startTime = performance.now()  let span = document.createElement('span')  span.style.color = 'red'  span.innerHTML = '<strong>插隊任務</strong>'  while (performance.now() - startTime < 1) {    // 阻塞 1 ms  }  container.appendChild(span)}

新增一個按鈕,用于觸發插隊任務的執行。0t628資訊網——每日最新資訊28at.com

pushBtn.onclick = function () {  taskQueue.push(highPriorityTask)}

我們來看一下執行效果,每當我點擊插隊任務按鈕,就會執行一個優先級更高的任務。0t628資訊網——每日最新資訊28at.com

0t628資訊網——每日最新資訊28at.com

代碼非常的簡單,不過理解可能需要稍微思考一下。因為 performWorkUnit 中遞歸在遍歷隊列 taskQueue,并且這個遞歸過程是一直處于中斷 -> 恢復的過程中,因此,當遍歷被中斷后,在它恢復之前,我們可以往 taskQueue 中插入新的任務到隊列頭部,當它重新開始遍歷時,新加入的任務就會被執行。0t628資訊網——每日最新資訊28at.com

這里一個小的細節是,在事件循環的運行規則中,點擊事件的回調會比 requestIdleCallback 更早執行。0t628資訊網——每日最新資訊28at.com

六、總結

這個邏輯就是 React 并發模式的底層原理。只不過在 React 中,同時兼容了同步更新與異步更新,并且設計了更加復雜的優先級機制,增加了更多場景的條件判斷,導致源碼看上去變得更加復雜了。0t628資訊網——每日最新資訊28at.com

當然,React 由于為了兼容更多的場景,改寫了任務中斷的判斷條件。因為在別的環境里,例如 node/React Native 等,不支持 requestIdleCallback,在這些場景之下,React 把中斷策略改為 5ms 中斷一次,然后利用 performance.now 或者 Date.now 來記錄時間。0t628資訊網——每日最新資訊28at.com

/* eslint-disable no-var */var getCurrentTime;var hasPerformanceNow = typeof performance === 'object' && typeof performance.now === 'function';if (hasPerformanceNow) {  var localPerformance = performance;  getCurrentTime = function () {    return localPerformance.now();  };} else {  var localDate = Date;  var initialTime = localDate.now();  getCurrentTime = function () {    return localDate.now() - initialTime;  };
function shouldYieldToHost() {  var timeElapsed = getCurrentTime() - startTime;  if (timeElapsed < frameInterval) { // 5ms    // 主線程只被阻塞了很短時間;    // smaller than a single frame. Don't yield yet.    return false;  }   // 主線程被阻塞的時間不可忽視  return true;}

并使用別的方式來替代 requestIdleCallback。0t628資訊網——每日最新資訊28at.com

  • node/old IE:setImmediate
  • DOM/worker:MessageChannel
  • 兜底方案:setTimeout
let schedulePerformWorkUntilDeadline;if (typeof localSetImmediate === 'function') {  // Node.js and old IE.  schedulePerformWorkUntilDeadline = () => {    localSetImmediate(performWorkUntilDeadline);  };} else if (typeof MessageChannel !== 'undefined') {  // DOM and Worker environments.  // We prefer MessageChannel because of the 4ms setTimeout clamping.  const channel = new MessageChannel();  const port = channel.port2;  channel.port1.onmessage = performWorkUntilDeadline;  schedulePerformWorkUntilDeadline = () => {    port.postMessage(null);  };} else {  // We should only fallback here in non-browser environments.  schedulePerformWorkUntilDeadline = () => {    // $FlowFixMe[not-a-function] nullable value    // @ts-ignore    localSetTimeout(performWorkUntilDeadline, 0);  };}

本文鏈接:http://m.www897cc.com/showinfo-26-87957-0.html從簡單中窺見高端,徹底搞懂任務可中斷機制與任務插隊機制

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 有哪些 Java 面試題 90% 的公司否會問到?

下一篇: RecyclerView中ItemDecoration的精妙用法,實現自定義分隔線、邊距和背景效果

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
日韩午夜电影av| 狠狠久久综合婷婷不卡| 欧美精品粉嫩高潮一区二区 | 亚洲国产成人不卡| 亚洲国产高潮在线观看| 一区二区三区高清视频在线观看| 亚洲欧美国产制服动漫| 久久久免费精品视频| 欧美伦理在线观看| 国产美女在线精品免费观看| 极品尤物久久久av免费看| 亚洲精品综合精品自拍| 午夜精品一区二区三区在线视 | 久久精品免费观看| 欧美肥婆bbw| 国产精品久久久亚洲一区| 激情婷婷亚洲| 亚洲天堂黄色| 久久一二三四| 国产精品久久激情| 亚洲第一区在线观看| 亚洲综合导航| 欧美成人精品激情在线观看| 国产精品捆绑调教| 亚洲激情另类| 欧美淫片网站| 欧美日韩一区二区三区免费看| 国产一区二区日韩| 亚洲婷婷国产精品电影人久久| 久久五月天婷婷| 国产精品久久久久一区二区三区| 亚洲国产黄色片| 欧美一区二区三区免费看| 欧美精品在线一区| 狠狠色香婷婷久久亚洲精品| 国产精品99久久99久久久二8 | 久久精品亚洲热| 欧美日精品一区视频| 极品少妇一区二区| 亚洲你懂的在线视频| 欧美粗暴jizz性欧美20| 国产午夜精品福利| 一区二区久久| 蜜桃视频一区| 国内视频一区| 亚洲一区二区三区精品视频| 欧美va天堂在线| 黄色精品在线看| 午夜精品亚洲| 欧美三级视频在线| 亚洲人体1000| 噜噜噜久久亚洲精品国产品小说| 国产毛片一区| 亚洲免费视频在线观看| 欧美日韩亚洲一区二区三区在线| 91久久国产综合久久| 久久综合色播五月| 国模吧视频一区| 欧美亚洲日本网站| 国产精品欧美久久| 中国日韩欧美久久久久久久久| 欧美二区在线播放| 亚洲国内精品在线| 蜜桃精品一区二区三区 | 亚洲激情黄色| 免费亚洲电影| 亚洲高清一区二| 久久综合九色99| 狠狠色综合一区二区| 久久超碰97人人做人人爱| 国产精品夜夜夜一区二区三区尤| av成人手机在线| 欧美日韩精品综合在线| 亚洲日韩欧美一区二区在线| 欧美高清在线精品一区| 亚洲国产一区二区在线| 久久久久一区二区| 激情成人综合网| 久久亚裔精品欧美| 亚洲福利视频二区| 男人插女人欧美| 最新中文字幕一区二区三区| 欧美高清在线视频| 亚洲精选91| 欧美三级电影精品| 亚洲综合大片69999| 国产精品一区二区在线观看| 欧美一区二区黄色| 国内精品福利| 美日韩精品视频| 亚洲精选久久| 亚洲一区免费网站| 国产欧亚日韩视频| 午夜精品久久久久久久久| 国产精品一区二区三区四区| 久久av一区二区三区漫画| 国产亚洲va综合人人澡精品| 欧美日韩卡一卡二| 欧美精品在线视频观看| 免费在线一区二区| 另类春色校园亚洲| 老鸭窝毛片一区二区三区| 欧美在线免费| 欧美精品久久久久久久久久| 亚洲高清中文字幕| 两个人的视频www国产精品| 狠狠狠色丁香婷婷综合久久五月| 这里只有精品丝袜| 国产精品中文在线| 狠狠干成人综合网| 久久久久综合一区二区三区| 激情六月综合| 欧美国产一区二区在线观看| 亚洲免费人成在线视频观看| 亚洲人精品午夜| 欧美午夜电影在线| 欧美一区二区三区电影在线观看| 怡红院精品视频在线观看极品| 欧美福利视频| 亚洲欧美精品在线观看| 国产一区欧美| 欧美高清一区二区| 午夜精品久久久久久久蜜桃app | 亚洲欧美日韩国产一区二区| 狠狠干综合网| 欧美日韩岛国| 亚洲欧美www| 在线免费观看视频一区| 欧美日韩亚洲一区三区| 午夜免费电影一区在线观看| 1024亚洲| 国产精品欧美日韩一区| 蜜桃久久精品乱码一区二区| 亚洲制服av| 亚洲清纯自拍| 国产喷白浆一区二区三区| 欧美福利网址| 欧美在线播放一区二区| 亚洲三级免费观看| 国产欧美亚洲视频| 欧美国产日本韩| 欧美一区二区在线免费观看| 亚洲茄子视频| 国产一区日韩一区| 欧美日韩午夜| 美国十次成人| 亚洲人www| 国内外成人免费视频| 欧美日韩综合一区| 欧美激情国产精品| 性色av一区二区三区在线观看 | 国产精品综合av一区二区国产馆| 裸体素人女欧美日韩| 欧美日韩性生活视频| 久久精品系列| 亚洲午夜在线视频| 亚洲国产精品久久久久婷婷老年| 国产精品免费观看在线| 欧美黑人在线观看| 久久三级福利| 亚洲永久在线| 亚洲日本欧美在线| 韩国女主播一区| 国产精品一卡二| 欧美日韩高清在线| 免费在线成人av| 久久精品国产视频| 亚洲欧美精品suv| 一区二区三区日韩在线观看| 亚洲国产精品电影| 国模私拍一区二区三区| 国产精品毛片大码女人| 欧美剧在线免费观看网站| 久久人人精品| 欧美一区二区三区婷婷月色| 中国成人黄色视屏| 国产美女精品一区二区三区| 免费看的黄色欧美网站| 日韩午夜免费| 亚洲激情视频在线观看| 精品动漫3d一区二区三区免费版 | 亚洲午夜免费福利视频| 亚洲精品午夜精品| 亚洲国产综合在线| 在线欧美一区| 激情一区二区| 国产一区二区三区免费在线观看| 国产精品久久久久永久免费观看| 欧美日韩另类视频| 欧美伦理一区二区| 欧美精品久久久久久久免费观看 | 欧美激情二区三区| 欧美二区在线观看| 美国十次成人| 免费亚洲电影在线| 女主播福利一区| 欧美成人国产一区二区| 欧美不卡三区| 欧美精品偷拍| 欧美日韩亚洲一区二区三区四区| 欧美日韩国产影院| 欧美日韩一区二区精品| 欧美午夜一区| 国产精品视频网址|