91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

三穗县| 普定县| 肇州县| 芒康县| 斗六市| 甘肃省| 疏附县| 卢氏县| 连云港市| 安平县| 沙雅县| 宝山区| 普格县| 江阴市| 监利县| 屯门区| 苏尼特右旗| 佛冈县| 民丰县| 寻甸| 武清区| 涿州市| 东丰县| 阳城县| 永吉县| 清徐县| 孟村| 思南县| 西平县| 金华市| 侯马市| 通渭县| 开封市| 新巴尔虎左旗| 安图县| 报价| 桂东县| 卓资县| 田林县| 江城| 平湖市|