亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

阿克陶县| 九龙坡区| 龙里县| 霍邱县| 盖州市| 寻乌县| 清河县| 三门峡市| 吉林省| 大竹县| 枣强县| 福建省| 灵台县| 永宁县| 尚义县| 龙井市| 富平县| 板桥市| 裕民县| 承德县| 银川市| 保靖县| 荣成市| 右玉县| 新宾| 徐闻县| 睢宁县| 彩票| 随州市| 齐齐哈尔市| 景泰县| 昭通市| 乌兰察布市| 扬中市| 石柱| 南昌县| 哈巴河县| 桂林市| 嘉义市| 社旗县| 成都市|