Współbieżność i równoległość w środowiskach obiektowych. Krzysztof Banaś Obliczenia równoległe 1

Podobne dokumenty
Współbieżność i równoległość w środowiskach obiektowych. Krzysztof Banaś Obliczenia równoległe 1

Programowanie równoległe i rozproszone. Monitory i zmienne warunku. Krzysztof Banaś Programowanie równoległe i rozproszone 1

Programowanie równoległe i rozproszone. W1. Wielowątkowość. Krzysztof Banaś Programowanie równoległe i rozproszone 1

Java. Wykład. Dariusz Wardowski, Katedra Analizy Nieliniowej, WMiI UŁ

Wątki. Definiowanie wątków jako klas potomnych Thread. Nadpisanie metody run().

Wielowątkowość. Programowanie w środowisku rozproszonym. Wykład 1.

Obliczenia równoległe i rozproszone w JAVIE. Michał Kozłowski 30 listopada 2003

Współbieżność w środowisku Java

Wątki w Javie. Piotr Tokarski

Język Java wątki (streszczenie)

Autor: dr inż. Zofia Kruczkiewicz, Programowanie aplikacji internetowych 1

Współbieżność w Javie

1 Wątki 1. 2 Tworzenie wątków 1. 3 Synchronizacja 3. 4 Dodatki 3. 5 Algorytmy sortowania 4

Wątek - definicja. Wykorzystanie kilku rdzeni procesora jednocześnie Zrównoleglenie obliczeń Jednoczesna obsługa ekranu i procesu obliczeniowego

Współbieżność w Javie

Podstawy współbieżności

WSPÓŁBIEŻNOŚĆ. MATERIAŁY:

Programowanie komputerów

Aplikacje w Javie- wykład 11 Wątki-podstawy

Język Java wątki (streszczenie)

Java. Programowanie Obiektowe Mateusz Cicheński

Kurs programowania. Wykład 8. Wojciech Macyna. 10 maj 2017

Języki i Techniki Programowania II. Wykład 7. Współbieżność 1

Kurs programowania. Wykład 8. Wojciech Macyna

Stworzenie klasy nie jest równoznaczne z wykorzystaniem wielowątkowości. Uzyskuje się ją dopiero poprzez inicjalizację wątku.

Programowanie wielowątkowe. Tomasz Borzyszkowski

Wielowątkowość mgr Tomasz Xięski, Instytut Informatyki, Uniwersytet Śląski Katowice, 2011

Java SE, Laboratorium nr 8 Wątki

JAVA W SUPER EXPRESOWEJ PIGUŁCE

Przetwarzanie równoległe i współbieżne

Programowanie współbieżne Wykład 5. Rafał Skinderowicz

Semafor nie jest mechanizmem strukturalnym. Aplikacje pisane z użyciem semaforów są podatne na błędy. Np. brak operacji sem_post blokuje aplikację.

Wykład 5. Synchronizacja (część II) Wojciech Kwedlo, Wykład z Systemów Operacyjnych -1- Wydział Informatyki PB

Semafor nie jest mechanizmem strukturalnym. Aplikacje pisane z użyciem semaforów są podatne na błędy. Np. brak operacji sem_post blokuje aplikację.

Monitory. Jarosław Kuchta

Wątki (Threads) Potrzeby. Przetwarzanie równoległe i współbieŝne. Cechy programowania wątkowego. Concurrent programming is like

1 Atrybuty i metody klasowe

Programowanie współbieżne Wykład 2. Rafał Skinderowicz

Programowanie wielowątkowe: podstawowe koncepcje, narzędzia w Javie. J. Starzyński, JiMP2, rok akad. 2005/2006

Wielowątkowość 1. Marcin Orchel. AGH University of Science and Technology in Poland 1 / 58

Interfejsy w Java. Przetwarzanie równoległe. Wątki.

Multimedia JAVA. Historia

Obiektowe programowanie rozproszone Java RMI. Krzysztof Banaś Systemy rozproszone 1

6.1 Pojęcie wątku programu 6.2 Klasy Timer, TimerTask 6.3 Klasa Thread 6.4 Synchronizacja pracy wątków 6.5 Grupowanie wątków

Wyjątki. Streszczenie Celem wykładu jest omówienie tematyki wyjątków w Javie. Czas wykładu 45 minut.

Programowanie w języku Java - Wyjątki, obsługa wyjątków, generowanie wyjątków

Programowanie współbieżne Laboratorium nr 11

Interfejsy. Programowanie obiektowe. Paweł Rogaliński Instytut Informatyki, Automatyki i Robotyki Politechniki Wrocławskiej

Programowanie współbieżne i rozproszone

Systemy operacyjne. Zajęcia 11. Monitory

1. Co można powiedzieć o poniższym kodzie (zakładając, że zaimportowano wszystkie niezbędne klasy)?

Programowanie obiektowe

Kurs programowania. Wykład 3. Wojciech Macyna. 22 marca 2019

Java - wprowadzenie. Programowanie Obiektowe Mateusz Cicheński

Programowanie współbieżne Laboratorium nr 12

Kurs programowania. Wykład 1. Wojciech Macyna. 3 marca 2016

Obszar statyczny dane dostępne w dowolnym momencie podczas pracy programu (wprowadzone słowem kluczowym static),

4.1 Napisz kod, w którym definiujesz, tworzysz oraz uruchamiasz wątki z uŝyciem klas java.lang.thread oraz java.lang.runnable.

Programowanie obiektowe

Język JAVA podstawy. Wykład 3, część 3. Jacek Rumiński. Politechnika Gdańska, Inżynieria Biomedyczna

Języki Programowania II Wykład 3. Java podstawy. Przypomnienie

Aplikacje Internetowe. Najprostsza aplikacja. Komponenty Javy. Podstawy języka Java

Podstawy Języka Java

Programowanie obiektowe

WIELOWĄTKOWOŚĆ. Waldemar Korłub. Platformy Technologiczne KASK ETI Politechnika Gdańska

W Javie wątki są obiektami zdefiniowanymi za pomocą specjalnego rodzaju klas.

Model pamięci. Rafał Skinderowicz

7 Pewne uzupełnienia Przepływ sterowania Układacze... 6

Dokumentacja do API Javy.

Programowanie w Internecie. Java

Wykład 2 Wybrane konstrukcje obiektowych języków programowania (1)

Polimorfizm, metody wirtualne i klasy abstrakcyjne

Wykład 8: Obsługa Wyjątków

Programowanie obiektowe

Kurs programowania. Wykład 13. Wojciech Macyna. 14 czerwiec 2017

Kurs programowania. Wykład 2. Wojciech Macyna. 17 marca 2016

Programowanie obiektowe. Literatura: Autor: dr inŝ. Zofia Kruczkiewicz

Wywoływanie metod zdalnych

Przetwarzanie wielowątkowe przetwarzanie współbieżne. Krzysztof Banaś Obliczenia równoległe 1

Podejście obiektowe do budowy systemów rozproszonych

Java RMI. Dariusz Wawrzyniak 1. Podejście obiektowe do budowy systemów rozproszonych. obiekt. interfejs. kliencka. sieć

Systemy Rozproszone - Ćwiczenie 4

Dawid Gierszewski Adam Hanasko

Klasy abstrakcyjne, interfejsy i polimorfizm

II Tworzenie klasy Prostokąt dziedziczącej z klasy wątku

Java: interfejsy i klasy wewnętrzne

Wykład 7: Pakiety i Interfejsy

Aplikacja wielowątkowa prosty komunikator

Java RMI. Dariusz Wawrzyniak 1. Podejście obiektowe do budowy systemów rozproszonych. obiekt. interfejs. kliencka. sieć

Aplikacje RMI Lab4

Programowanie obiektowe

Wykład 6: Dziedziczenie

Laboratorium 03: Podstawowe konstrukcje w języku Java [2h]

Konstruktory. Streszczenie Celem wykładu jest zaprezentowanie konstruktorów w Javie, syntaktyki oraz zalet ich stosowania. Czas wykładu 45 minut.

Kurs języka Python. Wątki

Programowanie obiektowe

Języki i metody programowania Java INF302W Wykład 2 (część 1)

Programowanie obiektowe

Marcin Luckner Politechnika Warszawska Wydział Matematyki i Nauk Informacyjnych

Programowanie współbieżne Wykład 10 Synchronizacja dostępu do współdzielonych zasobów. Iwona Kochańska

Transkrypt:

Współbieżność i równoległość w środowiskach obiektowych Krzysztof Banaś Obliczenia równoległe 1

Java Model współbieżności Javy opiera się na realizacji szeregu omawianych dotychczas elementów: zarządzanie wątkami operacje atomowe (wiele standardowych operacji na referencjach, zmiennych typów wbudowanych, operacje na zmiennych deklarowanych jako volatile, a także specjalne operacje takie jak np. compareandset, getandincrement itp.) mechanizmy synchronizacji (zamki, zmienne warunku i inne charakterystyczne dla funkcjonowania obiektów) klasy kontenerowe przystosowane do współbieżnego używania, takie jak: BlockingQueue, ConcurrentMap itp. Krzysztof Banaś Obliczenia równoległe 2

Wątki w Javie Narzędzia udostępniane przez Javę programistom tworzącym programy wielowątkowe należą do typowych konstrukcji obiektowych: klasy, interfejsy, metody wątek w Javie jest także obiektem (klasy Thread z pakietu java.lang) Wielowątkowość jest wbudowana w same podstawy systemu podstawowa klasa Object zawiera metody związane z przetwarzaniem współbieżnym (wait, notify, notifyall) każdy obiekt może stać się elementem przetwarzania współbieżnego Krzysztof Banaś Obliczenia równoległe 3

Wątki w Javie W jaki sposób sprawić żeby przetwarzanie stało się współbieżne zaprojektować obiekt z metodą przeznaczoną do rozpoczęcia przetwarzania współbieżnego uruchomić nowy wątek realizujący metodę Istnieją dwa sposoby uruchamiania wątków w Javie poprzez przekazanie obiektu, którego metodę chcemy wykonać, jako argumentu dla metody start obiektu klasy Thread nasz obiekt musi implementować interfejs Runnable uruchamiana metoda musi implementować metodę run poprzez uruchomienie metody start naszego obiektu nasz obiekt musi być obiektem klasy pochodnej klasy Thread uruchamiana metoda musi przeciążać metodę run Krzysztof Banaś Obliczenia równoległe 4

Wątki w Javie przykłady public class HelloRunnable implements Runnable { public void run() { System.out.println("Hello from a thread!"); public static void main(string args[]) { (new Thread(new HelloRunnable())).start(); public class HelloThread extends Thread { public void run() { System.out.println("Hello from a thread!"); public static void main(string args[]) { (new HelloThread()).start(); Klasa może dziedziczyć po innych klasach Klasa nie może dziedziczyć po innych klasach Krzysztof Banaś Obliczenia równoległe 5

Wątki w Javie Podstawowe metody klasy Thread (pakiet java.lang) void start() polecenie dla JVM uruchomienia metody run void run() uruchomienie metody run przekazanego obiektu implementującego interfejs Runnable (jeśli nie została przeciążona) static void sleep(long millis) uśpienie bieżącego wątku na określony czas void join(long millis), void join() oczekiwanie na zakończenie wątku void interrupt() przerwanie działania wątku (dokładniej ustawienie sygnalizatora przerwania przerwanie następuje jeśli wątek znajduje się wewnątrz metody dającej się przerwać, np. sleep, join, wait lub jeśli w trakcie realizacji wątku wywołana jest metoda: static boolean interrupted() sprawdzenie stanu sygnalizatora przerwania (dla bieżącego wątku) później powinna znajdować się reakcja wątku na próbę przerwania, np. zwrócenie wyjątku InterruptedException Krzysztof Banaś Obliczenia równoległe 6

Wątki w Javie przykład private static class obiektrunnable implements Runnable { public void run() { try { Thread.sleep(4000); for (int i = 0; i < number; i++) { obliczenia(); if (Thread.interrupted()) { throw new InterruptedException(); catch (InterruptedException e) { // reakcja na przerwanie Krzysztof Banaś Obliczenia równoległe 7

Wątki w Javie przykład public class TestThreads { public static void main(string args[]) throws InterruptedException { Thread t = new Thread(new obiektrunnable()); t.start(); t.join(1000); // oczekiwanie 1 sekundę if (t.isalive()) { t.interrupted(); t.join(); boolean isalive(), boolean isinterrupted() procedury sprawdzenia czy dany wątek jest wykonywany i czy został przerwany Krzysztof Banaś Obliczenia równoległe 8

Klasy, obiekty i współbieżność Atrybuty obiektów w programach współbieżnych niosą te same ryzyka błędów przy wykonaniu współbieżnym co zmienne globalne w programach proceduralnych Metody obiektów mogą zostać wywołane przez procedury z dowolnych wątków Wymaganiem dla każdej projektowanej klasy, której obiekty mogą być wykorzystywane przez obiekty innych klas jest bezpieczeństwo wątkowe (thread safety) Od wszystkich ogólnie dostępnych bibliotek wymaga się bezpieczeństwa wątkowego Pojęciem zbliżonym, choć innym jest reentrancy, cecha istotna także przy wykonaniu sekwencyjnym Pośrednim rozwiązaniem, nie zawsze możliwym jest wykorzystanie klas niezmiennych (immutable) Krzysztof Banaś Obliczenia równoległe 9

Monitory W ujęciu klasycznym monitor jest modułem posiadającym: stan atrybuty (stałe i zmienne) zachowanie metody (procedury i funkcje)) Metody monitora dzielą się na: udostępniane na zewnątrz publiczne wewnętrzne prywatne Podstawową zasadą działania monitora jest realizowanie sekcji krytycznej na poziomie obiektu: jeżeli jakiś proces/wątek rozpoczął realizację dowolnej publicznej metody, żaden inny proces/wątek nie może rozpocząć realizacji tej samej lub innej publicznej metody monitora inaczej: wewnątrz monitora może znajdować się tylko jeden proces/wątek Krzysztof Banaś Obliczenia równoległe 10

Monitory Realizacją wzajemnego wykluczania w dostępie do monitorów zarządza środowisko w ramach, którego funkcjonuje monitor Wątek, który wywołuje publiczną metodę monitora jest: wpuszczany do monitora, jeśli w monitorze nie ma innych wątków ustawiany w kolejce oczekujących wątków, jeśli w monitorze znajduje się wątek Po opuszczeniu monitora przez wątek system wznawia działanie pierwszego wątku w kolejce Istnieje jedna kolejka dla monitora (obsługuje próby wywołań wszystkich funkcji monitora) Monitor jest skuteczną realizacją wzajemnego wykluczania przy dostępie do swoich wewnętrznych zasobów inaczej: jeśli chcemy dostęp do jakiegoś zasobu uczynić wyłącznym dla pojedynczego wątku, należy umieścić ten zasób jako zasób wewnętrzny monitora Krzysztof Banaś Obliczenia równoległe 11

Wątki w Javie synchronizacja Działanie dowolnego obiektu w Javie można upodobnić do działania monitora przez określanie jego metod jako synchronizowanych Jeżeli metoda jest określona jako synchronizowana, wtedy jej realizacja przez jakiś wątek uniemożliwia realizację dowolnej synchronizowanej metody tego obiektu przez inne wątki (wątki zgłaszające chęć wywołania dowolnej synchronizowanej metody tego obiektu są w takiej sytuacji ustawiane w kolejce wątków oczekujących) ten sam wątek może realizować kolejne wywołania synchronizowanych metod w momencie zakończenia realizacji wszystkich synchronizowanych metod obiektu przez dany wątek JVM wznawia działanie pierwszego wątku oczekującego w kolejce Uwaga: konstruktory nie mogą być synchronizowane Krzysztof Banaś Obliczenia równoległe 12

Wątki w Javie synchronizacja Mechanizm synchronizacji w Javie opiera się na istnieniu wewnętrznych zamków monitorowych (monitor locks) zwanych często w skrócie monitorami Z każdym obiektem w Javie związany jest zamek monitorowy wątek rozpoczynający wykonywanie synchronizowanej metody obiektu zajmuje zamek tego obiektu żaden inny wątek nie otrzyma go dopóki dany wątek nie zwolni zamka zamek związany z danym obiektem można zająć także rozpoczynając wykonanie bloku synchronizowanego rozpoczynając wykonanie synchronizowanej statycznej funkcji klasy zajmuje się zamek związany z obiektem reprezentującym daną klasę Krzysztof Banaś Obliczenia równoległe 13

Wątki w Javie synchronizacja przykład public class Liczniki { private long c1 = 0; private long c2 = 0; public synchronized void inc1() { c1++; public synchronized void inc2() { c2++; Krzysztof Banaś Obliczenia równoległe 14

Wątki w Javie synchronizacja Synchronizowany blok oznacza się określeniem synchronized z argumentem będącym referencją do obiektu, którego zamek ma zostać zajęty najczęściej przesyłana jest referencja do obiektu, w klasie którego blok jest zdefiniowany (referencja this) dzięki temu tylko część kodu obiektu jest synchronizowana Można tworzyć odrębne obiekty, których jedyną funkcją będzie występowanie jako argument przy synchronizacji bloków takie obiekty pełnią rolę zbliżoną do muteksów jedna z różnic polega na braku realizacji metody trylock dlatego Java w pakiecie java.util.concurrency udostępnia interfejs Lock (posiadający standardowe funkcje muteksa) i jego kilka implementacji (np. typowy ReentrantLock) Krzysztof Banaś Obliczenia równoległe 15

Wątki w Javie synchronizacja przykład public class LicznikiMuteksy { private long c1 = 0; private long c2 = 0; private Object lock1 = new Object(); private Object lock2 = new Object(); public void inc1() { synchronized(lock1) { c1++; public void inc2() { synchronized(lock2) { c2++; Krzysztof Banaś Obliczenia równoległe 16

Wątki w Javie Nie tylko każdy obiekt w Javie może funkcjonować jak monitor, ale także dla każdego obiektu Javy możemy wywołać funkcje typowe dla zmiennych warunku: wait() tym razem bez argumentów, jedyną identyfikacją miejsca oczekiwania jest fakt wystąpienia w danym obiekcie notify() obudzenie jednego z wątków oczekujących w danym obiekcie (tak jak signal) notifyall() obudzenie wszystkich wątków oczekujących w danym obiekcie (tak jak broadcast) Powyższe funkcje zdefiniowane są w klasie Object, po której dziedziczy każda z klas Javy W pakiecie java.util.concurrency zdefiniowane są standardowe zmienne warunku (typ condition) Krzysztof Banaś Obliczenia równoległe 17

Java obiekt jako monitor przykład public class Pojemnik { private boolean pusty = true; public synchronized /* dane */ wyjmij() { while (pusty) { try { wait(); // oczekujemy gdzie? w obiekcie! catch (InterruptedException e) { /* reakcja na przerwanie */... // pobierz_dane pusty = true; notifyall(); // budzimy wszystkie wątki oczekujące w obiekcie Krzysztof Banaś Obliczenia równoległe 18

Java obiekt jako monitor przykład public synchronized void wloz( /* dane */ ) { while (!pusty) { try { wait();// funkcja wait nie posiada identyfikatora miejsca // oczekiwania, dlatego zalecane jest umieszczenie // jej w pętli sprawdzającej warunek! catch (InterruptedException e) {... // umieść_dane pusty = false; notifyall(); // nie ma określonego miejsca oczekiwania budzimy // wszystkie watki! Krzysztof Banaś Obliczenia równoległe 19