![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 17 Pomógł: 0 Dołączył: 9.02.2007 Ostrzeżenie: (0%) ![]() ![]() |
Czy w javascript jest jakiś prosty mechanizm synchronizacji, tudzież sposób, żeby uzyskać taki efekt.
Klasyczna sytuacja. Dwie funkcje, obie operują na tych samych zasobach. Jedna jest cykliczna np co 5 s. Trwa około 1s. Druga związana z eventem. Funkcja pierwsza ma w swojej treści czekanie setTimeout. Jeśli kliknę w trakcie czekania niestety nie uzyskam żądanego efektu ponieważ na jednym zasobie pracują dwie funkcje. Rozwiązaniem byłoby synchronizacja między nimi w ten sposób, że druga funkcja czeka na zakończenie pierwszej i wtedy się wykonuje, natomiast kolejne wywołanie funkcji pierwszej nastąpi dopiero po wykonaniu funkcji drugiej. |
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 6 476 Pomógł: 1306 Dołączył: 6.08.2006 Skąd: Kraków Ostrzeżenie: (0%) ![]() ![]() |
JS jest w pełni jednowątkowy (pomijając Web workery), stąd brak w tym języku jakichkolwiek mechanizmów synchronizacji. Jednak konieczność zsynchronizowania kilku różnych timeoutów wydaje się dosyć podejrzana - mógłbyś opisać swój problem i napisać dlaczego właśnie tak chcesz go rozwiązać? Wygląda na to, że mamy tutaj do czynienia z problemem XY.
Co do samego tematu - prawdopodobnie najłatwiej byłoby utworzyć jakąś kolejkę, gdzie co 5 sekund dodawałbyś pierwszą funkcję, a przy kliknięciu drugą. Samo wykonywanie funkcji z tej kolejki leżałoby w gestii innego obiektu, który mógłby wstrzymywać jej działanie do czasu zakończenia aktualnie przetwarzanej funkcji (łącznie z timeoutami wygenerowanymi w niej). |
|
|
![]() ![]() |
![]() |
Aktualny czas: 4.10.2025 - 13:27 |