cari
Rumahhujung hadapan webtutorial jsSetTimeout Tidak Sama seperti yang Anda Fikirkan

Apabila pembangun mula-mula menemui setTimeout dalam JavaScript, ia selalunya kelihatan seperti alat yang mudah untuk menangguhkan pelaksanaan fungsi. Walau bagaimanapun, memahami cara setTimeout berinteraksi dengan masa jalan JavaScript dan gelung acara boleh mendedahkan beberapa tingkah laku yang tidak dijangka, terutamanya dalam keadaan tertentu. Dan ia bukan sahaja setTimeout; kerumitan serupa timbul dengan setInterval dan fungsi tak segerak yang lain juga.

Gelung Acara: Gambaran Keseluruhan Ringkas
JavaScript adalah satu-benang, bermakna ia hanya boleh melaksanakan satu keping kod pada satu masa. Walaupun begitu, gelung acara membenarkan JavaScript untuk melaksanakan operasi tanpa sekatan. Ia mencapai ini dengan memunggah tugas seperti pemasa, permintaan rangkaian atau operasi I/O ke penyemak imbas atau API Node.js. Setelah tugasan ini selesai, fungsi panggil baliknya akan digilir semula ke gelung acara untuk dilaksanakan.

SetTimeout is Not the Same as You Think

Cara setTimeout berfungsi
Apabila anda memanggil setTimeout, anda meminta enjin JavaScript untuk melaksanakan fungsi selepas tempoh tertentu. Ini dilakukan dengan menambahkan fungsi panggil balik pada baris gilir gelung acara. Walau bagaimanapun, kelewatan yang dinyatakan ialah masa minimum enjin perlu menunggu sebelum menambah panggilan balik pada baris gilir, bukan masa pelaksanaan yang dijamin. Begini cara ia berfungsi secara terperinci:

  1. Panggilan Permulaan: Apabila setTimeout digunakan dengan fungsi panggil balik dan kelewatan, enjin JavaScript mendaftarkannya dalam persekitaran API Web yang disediakan oleh penyemak imbas atau Node.js.

  2. Pemasa: API Web memulakan pemasa untuk kelewatan yang ditentukan. Dalam tempoh ini, timbunan panggilan utama terus melaksanakan sebarang kod segerak yang mengikuti panggilan setTimeout.

  3. Baris Gilir Panggilan Balik: Setelah pemasa tamat tempoh, API Web tidak segera melaksanakan panggilan balik. Sebaliknya, ia mengalihkan fungsi panggil balik ke baris gilir acara.

  4. Gelung Peristiwa: Gelung acara, yang memantau tindanan panggilan dan baris gilir acara secara berterusan, mula dimainkan. Jika tindanan panggilan kosong, bermakna tiada tugas yang sedang dilaksanakan, gelung acara mengambil fungsi pertama daripada baris gilir acara dan menolaknya ke tindanan panggilan untuk pelaksanaan.

  5. Pelaksanaan: Fungsi panggil balik akhirnya dilaksanakan apabila ia mencapai bahagian atas tindanan panggilan.

Perlu ambil perhatian bahawa jika timbunan panggilan sibuk dengan tugas lain apabila pemasa tamat tempoh, mungkin terdapat kelewatan tambahan sebelum fungsi panggil balik dilaksanakan. Ini kerana gelung peristiwa mesti menunggu sehingga tindanan panggilan jelas sebelum ia boleh memproses fungsi panggil balik daripada baris gilir acara.

SetTimeout is Not the Same as You Think


Isu Penyekatan
Salah faham biasa ialah menganggap setTimeout akan sentiasa melaksanakan panggilan balik selepas kelewatan tepat ditentukan. Jika gelung peristiwa disekat oleh kod segerak, seperti gelung tak terhingga atau pengiraan jangka panjang, panggilan balik tidak akan dilaksanakan sehingga gelung acara bebas.

Pertimbangkan senario berikut:

console.log('Program started at: ' + new Date().toLocaleTimeString());

const programStartTime = Date.now();

function blockExecutionForThirtySeconds() {
  while (true) {
    const currentTime = Date.now();
    if (currentTime - programStartTime > 30000) {
      console.log('Blocking execution completed after 30 seconds...');
      return true;
    }
  }
}

console.log('Setting setTimeout for 1 second.');
setTimeout(() => {
  console.log('setTimeout executed after 30 seconds instead of 1 second: ' + new Date().toLocaleTimeString());
}, 1000);

blockExecutionForThirtySeconds();

Dalam contoh ini, fungsi blockExecutionForThirtySeconds menyekat gelung peristiwa dengan gelung tak terhingga yang berjalan selama 30 saat. Walaupun setTimeout ditetapkan untuk dilaksanakan selepas 1 saat, ia hanya akan dijalankan selepas blockExecutionForThirtySeconds selesai, iaitu selepas 30 saat.

SetTimeout is Not the Same as You Think

Implikasi Dunia Sebenar
Memahami tingkah laku ini adalah penting untuk pembangun, terutamanya apabila menulis kod yang melibatkan tamat masa, selang waktu atau pemprosesan tak segerak. Salah faham cara setTimeout berfungsi boleh membawa kepada isu prestasi dan pepijat yang sukar dikesan. Jika sekeping kod melakukan pengiraan berat atau tugasan yang berjalan lama dan menyekat gelung acara, semua panggilan balik setTimeout, resolusi janji dan operasi tak segerak lain akan ditangguhkan sehingga gelung acara bebas.

Kesimpulan
setTimeout ialah alat yang berkuasa dalam JavaScript untuk menangguhkan pelaksanaan kod, tetapi penting untuk memahami nuansanya. Kelewatan yang dinyatakan ialah masa minimum untuk menunggu sebelum fungsi boleh dibariskan untuk pelaksanaan. Masa pelaksanaan sebenar bergantung pada keadaan gelung acara. Menguasai operasi tak segerak dan pengurusan gelung acara adalah kunci untuk menulis aplikasi JavaScript yang cekap dan responsif.

Atas ialah kandungan terperinci SetTimeout Tidak Sama seperti yang Anda Fikirkan. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Ganti aksara rentetan dalam javascriptGanti aksara rentetan dalam javascriptMar 11, 2025 am 12:07 AM

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial Persediaan API Carian Google CustomTutorial Persediaan API Carian Google CustomMar 04, 2025 am 01:06 AM

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Contoh warna json failContoh warna json failMar 03, 2025 am 12:35 AM

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

10 JQuery Syntax Highlighters10 JQuery Syntax HighlightersMar 02, 2025 am 12:32 AM

Tingkatkan Penyampaian Kod Anda: 10 Penyeret Sintaks untuk Pemaju Coretan kod perkongsian di laman web atau blog anda adalah amalan biasa bagi pemaju. Memilih penyapu sintaks yang betul dapat meningkatkan daya tarikan dan daya tarikan visual dengan ketara. T

Bina Aplikasi Web Ajax anda sendiriBina Aplikasi Web Ajax anda sendiriMar 09, 2025 am 12:11 AM

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

8 plugin susun atur halaman jquery yang menakjubkan8 plugin susun atur halaman jquery yang menakjubkanMar 06, 2025 am 12:48 AM

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

10 JavaScript & JQuery MVC Tutorial10 JavaScript & JQuery MVC TutorialMar 02, 2025 am 01:16 AM

Artikel ini membentangkan pemilihan lebih daripada 10 tutorial mengenai rangka kerja javascript dan jquery model-view-controller (MVC), sesuai untuk meningkatkan kemahiran pembangunan web anda pada tahun baru. Tutorial ini merangkumi pelbagai topik, dari Foundatio

Apa itu ' ini ' Dalam JavaScript?Apa itu ' ini ' Dalam JavaScript?Mar 04, 2025 am 01:15 AM

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.