Rumah > hujung hadapan web > tutorial js > Analisis perbezaan antara pemasa nextTick() dan setImmediate() dalam node.js_node.js

Analisis perbezaan antara pemasa nextTick() dan setImmediate() dalam node.js_node.js

WBOY
Lepaskan: 2016-05-16 16:30:02
asal
1794 orang telah melayarinya

1. Masalah menggunakan pemasa dalam nod ialah ia tidak tepat Contohnya, setTimeout() menetapkan tugasan untuk dilaksanakan selepas 10ms, tetapi selepas 9ms, tugasan mengambil masa 5ms, dan apabila ia adalah pemasa. pusing lagi , telah ditangguhkan sebanyak 4ms.

Baiklah, itu sahaja tentang pemasa dalam nod.

2. Lihat kod:

Salin kod Kod adalah seperti berikut:

process.nextTick(function(){
console.log("Pelaksanaan tertunda");
});
console.log("Pelaksanaan biasa 1");
console.log("Pelaksanaan biasa 2");
console.log("Pelaksanaan biasa 3");
console.log("Pelaksanaan biasa 4");

Melalui contoh ini, saya rasa semua orang dapat melihat dengan jelas kegunaan nextTick() Ia digunakan terutamanya untuk pelaksanaan tak segerak.

Melihat kod:

Salin kod Kod adalah seperti berikut:

setImmediate(function(){
console.log("Pelaksanaan tertunda");
});
console.log("Pelaksanaan biasa");

Kami mendapati setImmediate juga dilaksanakan secara tidak segerak

Jadi apakah bezanya dengan nextTick()?

Lihat kod:

Kod 1:

Salin kod Kod adalah seperti berikut:
process.nextTick(function(){
console.log("nextTick delay")
});
setImmediate(function(){
console.log("setImmediate delay");
});
console.log("Pelaksanaan biasa");

Keputusan:

Kod 2:

Salin kod Kod adalah seperti berikut:
setImmediate(function(){
console.log("setImmediate delay");
});
process.nextTick(function(){
console.log("nextTick delay")
});
console.log("Pelaksanaan biasa");

Keputusan:

Saya mendapati bahawa walaupun susunan kod berbeza, hasil pelaksanaan adalah sama.

Ia boleh didapati daripada keputusan:

Keutamaan pelaksanaan fungsi panggil balik nextTick() adalah lebih tinggi daripada setImmediate();

process.nextTick() kepunyaan pemerhati melahu, dan setImmediate() kepunyaan pemerhati semak Dalam setiap pusingan pemeriksaan gelung, pemerhati melahu mendahului pemerhati I/O dan pemerhati I/O mendahului semakan. pemerhati.

Dari segi pelaksanaan khusus, fungsi panggil balik process.nextTick() disimpan dalam tatasusunan,

Keputusan setImmediate() disimpan dalam senarai terpaut.
Dari segi tingkah laku, process.nextTick() akan melaksanakan semua fungsi panggil balik dalam tatasusunan dalam setiap kitaran
Dan setImmediate() melaksanakan fungsi panggil balik dalam senarai terpaut dalam setiap kitaran

Salin kod Kod adalah seperti berikut:
//Tambah 2 fungsi panggil balik untuk nextTick()
process.nextTick(function(){
console.log("nextTick tertunda pelaksanaan 1");
});
process.nextTick(function(){
console.log("nextTick tertunda pelaksanaan 2");
});
//Tambah dua setImmediate() fungsi panggil balik
setImmediate(function(){
console.log("setImmediate delayed execution 1");
Process.nextTick(function(){
console.log("Sisipan kuat");
});
});
setImmediate(function(){
console.log("setImmediate delayed execution 2");
});
console.log("Pelaksanaan biasa");

Ia boleh dilihat daripada hasil pelaksanaan: apabila fungsi panggil balik pertama setImmediate() dilaksanakan, yang kedua tidak dilaksanakan serta-merta, tetapi memasuki kitaran seterusnya Tekan nextTick() sekali lagi, setImmediate( ) kali. Sebab reka bentuk ini adalah untuk memastikan setiap gelung boleh tamat dengan cepat dan menghalang CPU daripada menduduki terlalu banyak dan menyekat panggilan I/O berikutnya.

Di atas ialah maklumat tentang perbezaan antara pemasa nextTick() dan setImmediate() dalam node.js Adakah anda tahu perbezaan antara mereka?

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan