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.Aynı kategoriden
- Python’da bir stringi tamamen büyük harfe nasıl çevirebilirim?
- Bilgisayarlar nasıl çalışır?
- GraphQLde birleştirme stratejileri nelerdir ve hangi durumda hangi strateji tercih edilmelidir?
- Mantık kapısı problemleri hakkında temel bilgileri nereden öğrenebilirim?
- Yazılım projelerinde kullanılan version control sistemleri hangileridir ve nasıl çalışır?
- JavaScript’te bir değişkenin değerini nasıl kontrol edebilirim?
- ICloud yedeklenen fotoğraflar telefonda yer kaplar mı?
- Yazılım geliştirme sürecinde kod incelemesi nasıl yapılır?