中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

javascript如何阻塞程序運行

發布時間:2020-06-15 16:45:37 來源:億速云 閱讀:3240 作者:元一 欄目:web開發

背景:

JavaScript 是單線程的,一段 Js 程序的運行會占滿整個程序進程,我們通常會想方設法的通過異步編程來減少程序的阻塞,但在某些特殊的場景下我們需要阻塞程序的運行,那么今天就反其道而行之,看看通過怎么樣正常的方式來阻塞 Js 運行。

方法一 :

無限循環

  • 單線程的 JavaScript 可以給我們靈感,只要程序不斷的計算就可以阻塞程序的進程:

function sleep(d){  
    let t = Date.now();
    while(Date.now() - t <= d);  
}

function test() {
    console.log('sleep');
    sleep(10000);
    console.log('run');
}

test();
  • 但是這種方式其實是通過無限占用計算機的資源來造成假死狀態,它會消耗大量的 CPU,并沒有真正的讓程序進程停止,這種方式不可取。

方法二 : 

setTimeout

  • 我們直接用 setTimeout 回調的方式來阻斷程序的進程,當然它的確是沒有讓程序繼續進行并且讓 CPU 空閑下來,但是這種寫法并不是一種同步編程的方式:

function test() {
    console.log('sleep');
    setTimeout(function() {
        console.log('run');
    }, 10000)
}

await
  • ES 的高級版本出現了 Promise、await 等異步編程,它們讓程序的寫法更佳的優雅簡介,同樣也要借助于 setTimeout 來解決,建議采用此方式:

function sleep(ms) {
    return new Promise(resolve => setTimeout(resolve, ms));
}

async function test() {
    console.log('sleep');
    await sleep(10000);
    console.log('run');
}

test();

方法三 : 

generator & yield

  • ES6 的迭代器同樣也具備異步編程能力,但是這種寫法相當晦澀難懂,建議少用:

function sleep(time) {
    setTimeout(function () {
        test.next();
    }, time);
}

function* gen() {
    console.log('sleep');
    yield sleep(10000);
    console.log('10 second later');
}

let test = gen();
test.next();

總結

上述方法總結下來就是兩種,一種是強行阻斷式利用 Js 的單線程機制;另一種就是借助 Js 的異步事件機制+高級異步編程語法。當然我們在實際業務情況中使用阻塞 JS 進程的地方非常少,經常會通過 UI 來禁止用戶繼續操作,這樣的探索僅僅是搞清楚一些 Js 的基本原理,有助于我們很好的了解它。

以上就是javascript阻塞問題的詳細內容,更多請關注億速云其它相關文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永康市| 华亭县| 蒙阴县| 南江县| 桐城市| 分宜县| 合阳县| 滁州市| 岚皋县| 新宁县| 抚松县| 名山县| 调兵山市| 惠水县| 深州市| 新津县| 清徐县| 威远县| 芦山县| 甘谷县| 包头市| 商都县| 邹平县| 新兴县| 云浮市| 会昌县| 泗阳县| 于都县| 友谊县| 连南| 加查县| 江口县| 义乌市| 石河子市| 桓仁| 德格县| 宁德市| 彰化县| 古蔺县| 漠河县| 南雄市|