Programowanie obiektowe Andrzej Ziółkowski Wykład 8
Programowanie wielowątkowe i rozproszone Programowanie wielowątkowe – współbieżne wykonywanie wielu zadań w ramach jednego programu. Powody stosowania – przejrzystość programu, łatwa realizacja szybkiej reakcji na krytyczne zdarzenia (priorytety) Programowanie rozproszone – realizacja funkcji programu na wielu, często odległych procesorach pracujących w sieci. Powody stosowania – zwiększenie mocy obliczeniowych, łatwość aktualizacji (Web Services), niezawodność.
Programy wykonywane sekwencyjnie i równolegle
Wykonywanie programów (lub wątków) współbieżnie na jednym procesorze
Realizacja wielowątkowości w Javie Klasa Thread – obiekty tej klasy służą do zarządzania wątkami Wątkiem może być dowolny obiekt klasy implementującej interface Runnable, czyli klasy z metodą run wywoływaną przy uruchamianiu wątku. Obiektowi klasy Thread przyporządkowujemy obiekt, który będzie wątkiem i uruchamiamy go za pomocą metod klasy Thread
Wybrane metody klasy Thread start() – uruchamia wątek wywołując metodę run sleep(milisec) – wstrzymuje wątek na określony czas yield() – wstrzymuje chwilowo wątek, pozwala na wykonanie innych setPriority(priority) – ustawia priorytet dla wątku
Przykład class W1 implements Runnable { public void run() { // kod wykonywany w wątku 1 … } class W2 implements Runnable { // kod wykonywany w wątku 2 W1 w1 = new W1(); W2 w2 = new W2(); Thread th1 = new Thread(w1); Thread th2 = new Thread(w2); th1.start(); th2.start();
Problemy współużytkowania zasobów Wątek A modyfikuje strukturę danych D, wątek B z niej korzysta. Struktura danych modyfikowana przez A może być w pewnym momencie niespójna i jeśli wątek B w tym momencie z niej skorzysta otrzymamy błędne wyniki Rozwiązanie – blokowanie zasobów (groźba zakleszczeń) lub nieprzerywanie krytycznych fragmentów kodu (synchronizacja). W Javie możemy tworzyć nieprzerywalne metody za pomocą atrybutu synchronized.
Programowanie rozproszone Fragmenty programu wykonują się na wielu komputerach jednocześnie Brak wspólnej pamięci, przekazywanie informacji poprzez sieć w postaci komunikatów Duża niezawodność Wykorzystanie olbrzymich mocy obliczeniowych komputerów w sieci Problemy z alokacją zasobów i synchronizacją Wielkie możliwości ale chyba jeszcze nie potrafimy tworzyć programów rozproszonych i organizować przetwarzania
Przykłady projektów wykorzystujących przetwarzanie rozproszone SETI – „szukamy cywilizacji pozaziemskich”, przetwarzanie zebranych danych z radioteleskopu Arecibo w Puerto Rico w celu wyfiltrowania sygnałów, które można uznać za nienaturalne. 5.5 mln komputerów, uczestnicy z ponad 200 krajów. Google – indeksowanie zawartości stron internetowych. Wikipedia – encyklopedia tworzona przez społeczność internautów Aplikacje internetowe - systemy firmowe, sklepy, portale,… Web Services – usługi, które może wykorzystywać wielle aplikacji, np.. Prognozy pogody, kursy walut, notowania akcji,…
Programowanie rozproszone - perspektywy Ilość komputerów w sieci może przejść w nową jakość Może w końcu uda się wykorzystać metody sztucznej inteligencji Programowanie obiektowe nie koniecznie musi być tu wykorzystywane – bardziej przydatne mogą być modele programowania oparte na usługach, serwisach i wymianie komunikatów
Tworzenie apletu zawsze można skorzystać z Help-u Tworzenie apletu zawsze można skorzystać z Help-u. Wybieramy: Help, Help Contents a następnie w zakładce index wpisujemy słowo applet (uwaga dwa p)
Tworzenie apletu - help
Wybieramy: File, New Project i w dialogu zaznaczamy Java Class Library
W nazwie projektu wpisujemy nr ćwiczenia (cw5), folder projektu N:\public_html\po
Klikamy prawym przyciskiem myszki na nazwie projektu (cw5) i wybieramy New, File/Folder
Aby utworzyć aplet możemy wybrać Java Classes, JApplet lub Applet ale wygodniej będzie użyć …
Java GUI Forms i Java Applet Form aby móc korzystać z Designera przy projektowaniu wyglądu apletu.
Wpisujemy Class name cw5 i Package też cw5
W zakładce Source zobaczymy wygenerowany kod klasy cw5 wywiedzionej z javax.swing.JApplet
W zakładce Design możemy zaprojektować wygląd potrzebnego apletu W zakładce Design możemy zaprojektować wygląd potrzebnego apletu. Z Palette przeciągamy myszką JTextField, JButton, JLabel
Po rozmieszczeniu obiektów i ustaleniu ich wymiarów obiektów możemy, po kliknięciu prawym klawiszem myszki, zmienić nazwę obiektu i domyślny tekst
Wybieramy przycisk Oblicz i w zakładce Events w Properties wybieramy do obsługi zdarzenie mouseClicked
W wygenerowanej funkcji obsługi zdarzenia wpisujemy kod, który na oblicza liczbę liter i liczbę wyrazów w tekście wprowadzonym do pola ”tekst” i wyświetla wyniki.
Debugowanie apletu – kliknij prawym myszy na cw5 Debugowanie apletu – kliknij prawym myszy na cw5.java i wybierz Debug File
Aplety można debugować jak każdy inny program
W folderze public_html/po/cw5 umieszczamy plik index W folderze public_html/po/cw5 umieszczamy plik index.html (poniżej) oraz kopiujemy tu plik cw5.jar. Ustawiamy odpowiednie uprawnienia i aplet powinien działać <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Cw5</title> <meta content="text/html; charset=windows-1250" http-equiv="Content-Type"> <link href="std1.css" type="text/css" rel="stylesheet"> </head> <body> Cw5 - Teksty:<br><br> <applet code="cw5/cw5.class" archive="cw5.jar" width="400" height="420"> </applet> <br><br> </body> </html>
Jeśli aplet nie pokazuje się prawidłowo a w Java Console sygnalizowany jest błąd: Exception in thread "main" java.lang.NoClassDefFoundError: org/jdesktop/layout/GroupLayout$Group Może być konieczne dodanie wstawki w pliku build.xml i ponowna kompilacja --> <target name="-post-jar"> <jar update="true" destfile="${dist.jar}"> <zipfileset src="${libs.swing-layout.classpath}"/> </jar> </target> </project>