Rumah > hujung hadapan web > tutorial js > Mengapa Fungsi Panggilan Balik Kadang-kadang Dilaksanakan Secara Asynchronous, Walaupun Tiada Sintaks Eksplisit?

Mengapa Fungsi Panggilan Balik Kadang-kadang Dilaksanakan Secara Asynchronous, Walaupun Tiada Sintaks Eksplisit?

Mary-Kate Olsen
Lepaskan: 2024-11-10 12:57:02
asal
378 orang telah melayarinya

Why Do Callback Functions Sometimes Execute Asynchronously, Despite No Explicit Syntax?

Mengapa Fungsi Panggilan Balik Dilaksanakan Secara Asynchronous?

Dalam dunia pengaturcaraan, fungsi panggil balik adalah bahagian penting dalam pengaturcaraan tak segerak. Tetapi apakah sebenarnya dalam sintaks yang mencetuskan pelaksanaan tak segerak mereka? Yang menghairankan, jawapannya bukan terletak pada sintaks itu sendiri, tetapi pada butiran pelaksanaan yang mendasari.

Menyahkod Sifat Panggilan Balik Tidak Menyekat

برخلاف تصور عمومی، nothing in sintaks fungsi panggil balik secara eksplisit mengisytiharkannya sebagai tak segerak. Ambil contoh berikut:

setTimeout(function() {
  console.log("Asynchronous Callback");
}, 100);
Salin selepas log masuk
my_array.forEach(function(element) {
  console.log("Synchronous Callback");
});
Salin selepas log masuk

Kedua-dua contoh menggunakan fungsi panggil balik, tetapi hanya yang pertama tidak segerak, ditangguhkan selama 100 milisaat menggunakan setTimeout. Kaedah kedua dilaksanakan secara serentak, serta-merta melelang melalui tatasusunan.

Satu-satunya kaedah yang boleh dipercayai untuk menentukan gelagat panggilan balik adalah dengan merujuk dokumentasi atau melakukan ujian untuk mengesahkan masa pelaksanaannya.

Keajaiban Di Sebalik Fungsi Asynchronous

Javascript, sebagai bahasa, tidak menyediakan pelaksanaan tak segerak untuk fungsi. Untuk mencapai matlamat ini, sama ada fungsi tak segerak lain (seperti setTimeout atau pekerja web) digunakan atau fungsi itu ditulis dalam C.

Fungsi berkod C, seperti setTimeout, melaksanakan ketidaksegerakan melalui gelung acara.

Gelung Acara dan Pelaksanaan Asynchronous

The gelung peristiwa ialah bahagian asas seni bina pelayar web. Ia mengendalikan operasi I/O secara tidak menyekat, membenarkan berbilang tugasan berlaku serentak.

Gelung peristiwa bergantung terutamanya pada pilih() atau fungsi serupa dalam C untuk memantau peristiwa I/O. Apabila data tersedia, jurubahasa memanggil panggil balik yang sesuai yang dikaitkan dengan saluran I/O tersebut.

Pengurusan Tamat Masa dan Pekerja Web

Gelung acara mengendalikan acara tamat masa dengan lancar dan pekerja web. Dengan menguruskan tamat masa yang diluluskan untuk select(), ia boleh menjadualkan panggilan balik untuk dilaksanakan pada masa hadapan. Pekerja web, yang dijalankan pada urutan berasingan, juga berinteraksi dengan gelung acara untuk berkomunikasi dengan urutan utama.

Sumber Tambahan

Untuk pemahaman yang lebih mendalam tentang tidak menyekat Pengaturcaraan I/O dalam C, rujuk: http://www.gnu.org/software/libc/manual/html_node/Waiting-for-I_002fO.html

Terokai artikel berikut untuk mendapatkan maklumat lanjut:

  • Adakah nodejs mewakili corak reka bentuk Reaktor atau Proaktor?
  • Prestasi NodeJS dengan jumlah yang besar panggilan balik

Atas ialah kandungan terperinci Mengapa Fungsi Panggilan Balik Kadang-kadang Dilaksanakan Secara Asynchronous, Walaupun Tiada Sintaks Eksplisit?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan