Trwają zapisy do grupy

Wielowątkowe i asynchroniczne aplikacje w Javie

Podczas szkolenia uczestnicy poznają metody tworzenia wielowątkowych i asynchronicznych aplikacji z uwzględnieniem nowoczesnych technik i narzędzi dostępnych w najnowszych wersjach języka Java.

2150 PLN+23% VAT (2644 PLN brutto / 1 os.)

Czas trwania szkolenia:2 dni (16h)

Poziom zaawansowania:

Kod kursu:J/PARA

javamultithreading

Dostępne terminy

  • Termin
  • Trener
  • Cena
  • Zapis
  • Lokalizacja

Termin:

28 listopada
Trwają zapisy na szkolenie

Trener:

Mateusz Kamiński

Cena:

2150 PLN netto
Ikona podpowiedziDowiedz się więcej o cenach szkoleń - zapraszamy do kontaktu
+23% VAT

Lokalizacja:

Zdalne
Zdalne
Ikona podpowiedziZapytaj o inne lokalizacje - w tym celu skorzystaj z chatu

Forma szkolenia

Interesuje Cię szkolenie stacjonarne?

Dostępne terminy

Interesują Cię inne terminy?

Wielowątkowe i asynchroniczne aplikacje w Javie

Cele szkolenia

  • Nabycie umiejętności programowania wielowątkowego oraz asynchronicznego w Javie z uwzględnieniem nowości wprowadzanych do języka Java przez ostatnie lata
  • Poznanie niuansów języka Java w zakresie dostępnych elementów wspomagających programowanie wielowątkowe i asynchroniczne
  • Omówienie i praktyczne przetestowanie wpływu zastosowanych rozwiązań na wydajność napisanego kodu
  • Poznanie możliwości debugowania i testowania wielowątkowej aplikacji

Dla kogo?

  • Osób chcących poznać możliwości programowania wielowątkowego i asynchronicznego w języku Java

Zalety

  • Przekrojowe omawianie zagadnień oraz przykłady oparte o życiowe problemy
  • Promowanie obowiązujących konwencji i dobrych praktyk programistycznych
  • Minimalna teoria oparta na praktycznych przykładach i warsztatach
  • Praktyczna wiedza uwzględniająca zmiany wprowadzone w najnowszych wydaniach Javy

Wymagania

  • Podstawowa umiejętność programowania w języku Java

W cenie otrzymasz:

  • Materiały szkoleniowe
  • Certyfikat ukończenia szkolenia
  • W przypadku szkolenia w trybie stacjonarnym zapewnimy Ci również lunch oraz sprzęt niezbędny do nauki

Program

Pobierz program w PDF

Terminologia na przykładzie JVM

  • Programowanie współbieżne, wielowątkowe, asynchroniczne
  • Niebezpieczeństwa związane z wielowątkowymi procesami - wyścigi, deadlock, zagłodzenie, livelock
  • Sekcja krytyczna
  • Cechy wątków w Javie
  • Słowo kluczowe volatile oraz synchronized
  • Zasady działania wielowątkowości w ramach JVM - Java Memory Model
  • Poprawne tworzenie typów Thread-Safe

Tworzenie i koordynacja pracy wątków

  • Standardowe i nowe API tworzenia wątków w Javie
  • Interfejsy funkcyjne zadań realizowanych na wątkach - Runnable / Callable
  • Typ CompletableFuture
  • LockSupport park / unpark vs standardowy Thread.wait
  • Asynchroniczna obsługa zapytań typu REST na przykładzie wbudowanego w JDK HttpClient

Egzekutory

  • Porównanie dostępnych typów egzekutorów
  • Harmonogramowanie zadań asynchronicznych z wykorzystaniem egzekutorów

Synchronizacja wątków z użyciem blokad jawnych i niejawnych

  • proste blokady obiektowe - ReentrantLock, ReadWriteLock, StampedLock
  • Semafor a licznik CountDownLatch
  • CyclicBarrier i Phaser

Kolekcje i strumienie wielowątkowe

  • Podstawowe kolekcje blokujące: ConcurrentHashMap, ConcurrentLinkedDeque/Queue
  • Kolekcje skalowalne i automatycznie sortujące zawartość: ConcurrentSkipListMap, ConcurrentSkipListSet
  • Kolekcje kopiujące zawartość: CopyOnWriteArrayList, CopyOnWriteArraySet
  • Typy kolejek: porównanie interfejs TransferQueue, BlockingQueue wraz z dostępnymi implementacjami
  • Wrappery na istniejące kolekcje: java.util.Collections.synchronized...
  • Strumienie wielowątkowe
  • Zagrożenia płynące z naiwnego używania strumieni wielowątkowych

Wykorzystanie istotnych elementów java.util.concurrent

  • Zastosowanie typów atomowych
  • Framework Fork/Join
  • Typy reaktywne: Flow / Publisher / Subscriber

Wirtualne wątki

  • Porównanie wątków fizycznych i wirtualnych
  • Potencjalne problemy w używaniu wirtualnych wątków
  • Typ ThreadLocal a ScopedValue
  • Structured Concurrency - nowe spojrzenie na programowanie asynchroniczne w Javie
  • Popularne frameworki a wirtualne wątki

Debugowanie / testowanie rozwiązań wielowątkowych

  • Problemy w testowaniu aplikacji wielowątkowych
  • Debugowanie z wykorzystaniem VisualVM / jstack
  • Techniki pisania testów jednostkowych dla kodu wielowątkowego
  • Oficjalne narzędzie od JDK: jcstress

Project reactor (Opcjonalnie)

Autorem szkolenia jest Mateusz Kamiński

Absolwent informatyki Instytutu Informatyki na Wydziale Elektroniki i Technik Informacyjnych Politechniki Warszawskiej, obecnie Engineering Manager w Sages. Przez wiele lat prowadził zespoły programistyczne wytwarzające współczesne oprogramowanie, kładąc przy tym nacisk na jakość i elastyczność tworzonych rozwiązań. Od kilku lat lider zespołu technicznego Sages, który to w niedługim czasie z niewielkiego startupu rozwinął się w software house. Od początków kariery był mentorem w zespołach programistycznych,…