最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧

來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 21:29:32
文檔

javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧

javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧:Javascript 引擎的單線程特性使得在處理一個較大的循環(huán)遍歷時會長時間獨占線程,導(dǎo)致其它事件(例如用戶操作)無法及時響應(yīng),嚴(yán)重時造成卡頓甚至是假死現(xiàn)象。為解決上述問題,一種可行機制是將大的循環(huán)拆分成若干小的循環(huán)片段分片執(zhí)行,使得Javascript
推薦度:
導(dǎo)讀javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧:Javascript 引擎的單線程特性使得在處理一個較大的循環(huán)遍歷時會長時間獨占線程,導(dǎo)致其它事件(例如用戶操作)無法及時響應(yīng),嚴(yán)重時造成卡頓甚至是假死現(xiàn)象。為解決上述問題,一種可行機制是將大的循環(huán)拆分成若干小的循環(huán)片段分片執(zhí)行,使得Javascript

Javascript 引擎的單線程特性使得在處理一個較大的循環(huán)遍歷時會長時間獨占線程,導(dǎo)致其它事件(例如用戶操作)無法及時響應(yīng),嚴(yán)重時造成卡頓甚至是假死現(xiàn)象。為解決上述問題,一種可行機制是將大的循環(huán)拆分成若干小的循環(huán)片段分片執(zhí)行,使得Javascript 引擎有時機在各段之間插入執(zhí)行其它事情,從而有效改善性能體驗

Ansync.js

代碼如下:
function Ansync (totalCount, segmentCount, workCallback, returnCallback)
{
var num_of_item_for_each_segment = segmentCount;
var num_of_segment = Math.ceil(totalCount / num_of_item_for_each_segment);
var count_of_segment = 0;
var timer;
var start, end;
this.process = function(scope, timeout)
{
if (scope != undefined)
{
workCallback = workCallback.bind(scope);
returnCallback = returnCallback ? returnCallback.bind(scope) : undefined;
}
if (count_of_segment == num_of_segment)
{
clearTimeout(timer);
if (returnCallback != undefined)
returnCallback();
}
else
{
start = count_of_segment * num_of_item_for_each_segment;
end = Math.min(totalCount, (count_of_segment + 1) * num_of_item_for_each_segment);
if (num_of_segment == 1)//needn't create timer
{
workCallback(start, end);
count_of_segment = 1;
this.process();
}
else
{
timer = setTimeout(function ansyncTimeout(){
if (workCallback(start, end)) //finish process if function returns true
{
count_of_segment = num_of_segment;
}
else
{
count_of_segment++;
}
this.scope.process();
}.bind({scope: this}),timeout == undefined ? Ansync.TimeOut : timeout);
}
}
}
}
Ansync.TimeOut = 5;

方法很簡單,但是很實用,有相同項目需求的小伙伴參考下吧

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧

javascript引擎長時間獨占線程造成卡頓的解決方案_javascript技巧:Javascript 引擎的單線程特性使得在處理一個較大的循環(huán)遍歷時會長時間獨占線程,導(dǎo)致其它事件(例如用戶操作)無法及時響應(yīng),嚴(yán)重時造成卡頓甚至是假死現(xiàn)象。為解決上述問題,一種可行機制是將大的循環(huán)拆分成若干小的循環(huán)片段分片執(zhí)行,使得Javascript
推薦度:
標(biāo)簽: 卡頓 造成 解決
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top