JavaScript’te event loop nasıl çalışır?

JavaScript'nde Event Loop

JavaScript, tek iş parçacıklı bir dil olduğundan, aynı anda yalnızca bir işlem gerçekleştirebilir. Event loop, asenkron işlemleri yönetmek için kullanılan bir mekanizmadır.

Çalışma Prensibi

JavaScript'te event loop şu şekilde çalışır:
  • Call Stack: İşlem sırası, iş parçacığında izlenir. Fonksiyonlar buraya eklenir ve tamamlandıkça çıkarılır.
  • Web APIs: Asenkron işlemler (örneğin, setTimeout, AJAX) burada işlenir. İşlemler tamamlandığında callback fonksiyonları işleme alınmak üzere kuyruklanır.
  • Callback Queue: Web APIs'den dönen callback fonksiyonları buraya eklenir. Call stack boşaldığında buradan alınarak işlenir.
  • Event Loop: Call stack ve callback queue arasında sürekli bir döngü oluşturarak, call stack boşsa callback queue'dan bir fonksiyon alır ve çalıştırır.

Örnek Senaryo

1. Bir fonksiyon çağrılır ve call stack'e eklenir. 2. Fonksiyon içinde bir asenkron işlem (örneğin setTimeout) başlatılır. 3. Asenkron işlem tamamlandığında, ilgili callback fonksiyonu callback queue'ya eklenir. 4. Call stack boşaldığında, event loop callback queue'dan bir fonksiyonu alıp call stack'e ekler ve çalıştırır. Bu döngü sürekli olarak devam eder ve JavaScript programlarının asenkron olarak çalışmasını sağlar.


🐞

Hata bildir

Paylaş