做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 21:29:32
文檔

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

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

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

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;

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

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

文檔

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

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

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 大田县| 武定县| 出国| 梁山县| 西乌| 乡城县| 桃江县| 长白| 保德县| 永新县| 菏泽市| 盐池县| 娱乐| 清水河县| 灵璧县| 金溪县| 宜阳县| 晋江市| 辽宁省| 泰宁县| 新绛县| 文水县| 历史| 桑日县| 大渡口区| 桂阳县| 乾安县| 深州市| 关岭| 特克斯县| 聂拉木县| 潼南县| 泰来县| 临城县| 蓬溪县| 正阳县| 东城区| 柞水县| 六盘水市| 仁寿县| 沁源县|