Vue3源碼reactivity響應式篇之批量更新

概述

在vue3響應式系統設計中,批量更新是優化性能的核心機制之一。當短時間內頻繁多次修改響應式數據時,批量更新可以避免頻繁觸發訂閱者的更新操作,將這些更新操作合并為一次,從而減少不必要的計算和DOM操作。

批量更新也是利用鏈表的方式實現。

批量更新的實現

核心變量

批量更新的實現依賴于3個核心變量:batchDepthbatchedSubbatchedComputed

let batchDepth = 0; // 批量更新的嵌套深度
let batchedSub;// 存儲待執行的普通訂閱者隊列
let batchedComputed; // 存儲待執行的計算屬性computed訂閱者隊列(單獨處理,有優先級)

核心方法

批量更新的實現依賴于3個核心方法:startBatchendBatchbatch

batch

batch方法的作用是將訂閱者sub加入批量隊列中。sub通常是ReactiveEffect實例,該方法不會立即執行更新,只是暫存將sub加入批量隊列中,等待endBatch方法調用時統一執行。

batch方法的實現如下:

function batch(sub, isComputed = false) {// 標記訂閱者為 EffectFlags.NOTIFIED "已加入批量隊列"  sub.flags |= 8;if (isComputed) {// 若為計算屬性訂閱者,則加入計算屬性鏈表中(單獨維護)sub.next = batchedComputed; // 新訂閱者放在鏈表的頭部batchedComputed = sub;return;}// 若為普通訂閱者,則加入普通訂閱者鏈表中sub.next = batchedSub;batchedSub = sub;
}
startBatch

startBatch方法的作用是開啟批量更新,將batchDepth1,說明后續的更新操作會被暫存,不立即執行。

function startBatch() {batchDepth++;
}
endBatch

endBatch就是當所有嵌套的批量更新都結束后(batchDepth減為0),執行鏈表中所有暫存的訂閱者更新,并清理狀態。

endBatch的源碼實現如下:

function endBatch() {// 若批量更新仍有嵌套(深度未到0),不執行實際更新   if (--batchDepth > 0) {return;}// 處理計算屬性訂閱者鏈表if (batchedComputed) {let e = batchedComputed;batchedComputed = void 0; // 清空隊列while (e) {const next = e.next;e.next = void 0;// 重置鏈表指針e.flags &= -9;// 清除批量隊列的標志e = next;}}// 處理普通訂閱者隊列并執行更新let error;while (batchedSub) {let e = batchedSub;batchedSub = void 0; // 清空隊列while (e) {const next = e.next;e.next = void 0; // 重置鏈表指針e.flags &= -9; // 清除批量隊列的標志// 若訂閱者標記為需要觸發更新,則執行更新,調用訂閱者的trigger方法if (e.flags & 1) {try {;e.trigger();} catch (err) {// 暫存錯誤  if (!error) error = err;}}// 遍歷下一個訂閱者e = next;}}// 處理錯誤if (error) throw error;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/921952.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/921952.shtml
英文地址,請注明出處:http://en.pswp.cn/news/921952.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

AI 模型訓練過程中參數用BF16轉向FP16的原因

大模型訓練從 FP16 轉向 BF16 是一個關鍵的技術演進,其核心原因在于 BF16 在動態范圍和精度之間取得了更優的平衡,從而極大地提升了訓練(尤其是大模型訓練)的穩定性和有效性。 1. 背景 為什么需要半精度浮點數 (FP16)?…

python網絡爬取個人學習指南-(五)

**************************************************************************************************************author:keyinfodate:2025-09-09 23:50title:網絡信息爬取之多聯級標題內容點擊****************************************…

RAG - 檢索增強生成

第一部分:RAG 詳解一、RAG 是什么?RAG(Retrieval-Augmented Generation,檢索增強生成)是一種將信息檢索(或知識檢索)與大語言模型(LLM)的生成能力相結合的技術框架。它的…

大數據畢業設計選題推薦-基于大數據的分化型甲狀腺癌復發數據可視化分析系統-Spark-Hadoop-Bigdata

?作者主頁:IT研究室? 個人簡介:曾從事計算機專業培訓教學,擅長Java、Python、微信小程序、Golang、安卓Android等項目實戰。接項目定制開發、代碼講解、答辯教學、文檔編寫、降重等。 ?文末獲取源碼? 精彩專欄推薦??? Java項目 Python…

Spring Bean掃描

好的,沒有問題。基于我們之前討論的內容,這是一篇關于 Spring Bean 掃描問題的深度解析博客。Spring Bean掃描作者:Gz | 發布時間:2025年9月9日🎯 Spring如何找到你的Bean? 首先要理解原理。Spring的組件掃…

【 運維相關】-- HTTP 壓測/負載發生器之新秀 oha

目錄 oha 項目分析(hatoo/oha) 一、概述 二、安裝 三、快速上手 三、常用參數(摘選) 四、輸出解讀(終端 TUI) 五、與其它工具對比 六、最佳實踐 七、注意事項 八、參考 oha 項目分析(h…

淘寶閃購基于FlinkPaimon的Lakehouse生產實踐:從實時數倉到湖倉一體化的演進之路

摘要:本文整理自淘寶閃購(餓了么)大數據架構師王沛斌老師在 Flink Forward Asia 2025 城市巡回上海站的分享。引言在數字化轉型的浪潮中,企業對實時數據處理的需求日益增長。傳統的實時數倉架構在面對業務快速變化和數據規模爆炸性增長時,逐漸…

Android應用添加日歷提醒功能

功能 在安卓應用里調用系統日歷&#xff0c;直接創建一個帶提醒的日歷事件&#xff0c;甚至不需要跳轉到日歷界面&#xff0c;只需要獲取系統日歷的讀取權限即可。 需要的權限 在AndroidManifest.xml里添加 <uses-permission android:name"android.permission.READ_CAL…

?Git Bisect 二分查找定位錯誤總結

# Git Bisect 二分查找指南## 1. 基本原理&#xff08;ASCII示意圖&#xff09; 假設提交歷史是一條時間線&#xff0c;Ggood&#xff08;正常&#xff09;&#xff0c;Bbad&#xff08;異常&#xff09;&#xff1a;提交順序: G --- G --- G --- B --- B --- B | | | 初始正常…

ThingsKit物聯網平臺 v2.0.0 發布|前端UI重構、底層架構升級

v2.0.0 Release發布日期&#xff1a;2025/08/25 代碼標簽&#xff1a;v2.0.0_Release&#x1f947; 新增功能國標級聯&#xff08;支持上級、下級國標級聯&#xff09;視頻回放、錄像計劃&#xff08;用戶可以通過錄像計劃生成對應的視頻回放并查看&#xff09;Modbus_TCP協…

Lua > Mac Mini M4安裝openresty

Mac Mini M4安裝openresty 主要參考 https://www.cnblogs.com/helios-fz/p/15703260.html brew uninstall nginxbrew update brew install pcre openssl #brew install geoip# brew tap openresty/brew # brew install openresty # brew install openresty/brew/openresty# VER…

【多線程案例】:單例模式

多線程案例8.1 單例模式餓漢模式懶漢模式懶漢模式-單線程版懶漢模式-多線程版懶漢模式-多線程版(改進)8.1 單例模式 單個實例. 在一個 java 進程中, 要求指定的類,只能有唯–個實例。&#xff08;嘗試 new 多個實例的時候, 就會直接編譯報錯&#xff09; 單例模式是校招中最常…

【Python/Pytorch】-- 貝葉斯定理

文章目錄 文章目錄01 貝葉斯定理的理解02 在MRI重建領域應用01 貝葉斯定理的理解 貝葉斯定理的基本公式&#xff1a;P(A|B)P(B|A)*P(A) / P(B) 首先是如何理解這個公式&#xff1f; 在B事件發生的條件下&#xff0c;A發生的概率 P(A|B) 在B事件發生的條件下&#xff0c;A和B同…

子網掩碼的隱形陷阱:為何能ping通卻無法HTTPS訪問

問題現象深度解析在近期企業網絡維護中&#xff0c;運維團隊發現一個具有教學意義的典型案例&#xff1a;某臺部署在10.165.111.0/24網段的業務服務器&#xff08;10.165.111.71&#xff09;可以成功ping通目標中間件主機(10.165.110.11)&#xff0c;但通過HTTPS協議訪問https:…

【ArcGIS】如何編輯圖層的屬性表

GIS按屬性選擇后刪除所選項呈現灰色_arcgis刪除字段灰色-CSDN博客

大數據各組件flume,datax,presto,DolphinScheduler,findBI在大數據數倉架構中的作用和功能。

一、數據倉庫核心價值鋪墊在講具體技術前&#xff0c;先明確數據倉庫&#xff08;Data Warehouse&#xff0c;簡稱數倉&#xff09; 的核心作用&#xff1a; 數據倉庫是 “整合企業多源數據、按業務主題組織、支持決策分析” 的結構化數據存儲體系&#xff0c;核心價值是打破數…

React From表單使用Formik和yup進行校驗

一、Formik的使用 官方文檔地址&#xff1a;https://formik.org/docs/tutorial#validation 首先安裝依賴 yarn add formik2.導入并初始化 import { useFormik } from formik; initialValues&#xff1a;初始化 輸入框的密碼和賬號 onSubmit&#xff1a;當點擊提交按鈕時&am…

netty-scoket.io路徑配置

1、服務端代碼 package com.yh.service.socket;import com.corundumstudio.socketio.SocketIOServer; import com.corundumstudio.socketio.store.RedissonStoreFactory; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory…

20250910榮品RD-RK3588-MID開發板在Android13系統下解決點卡迪的屏閃屏的問題

20250910榮品RD-RK3588-MID開發板在Android13系統下解決點卡迪的屏閃屏的問題 2025/9/5 15:44緣起&#xff1a;榮品RD-RK3588-MID開發板在Android13系統下解決點卡迪的屏。 按 POWER按鍵 關機之后&#xff0c;2s之內再次短按 POWER按鍵&#xff0c;開機之后屏會抖動。 2s后短按…

正態分布 - 計算 Z-Score 的 無偏估計

正態分布 - 計算 Z-Score 的 無偏估計 flyfish Z-Score公式與計算步驟 1 公式&#xff08;樣本Z-Score&#xff09; 實際應用中&#xff0c;我們幾乎不知道“總體均值/標準差”&#xff0c;所以常用樣本數據計算&#xff1a; zixi?xˉsz_i \frac{x_i - \bar{x}}{s}zi?sxi??…