Προγραμματισμός ΙΙ (Java) 10. Πολυνηματικές εφαρμογές Τεκμηρίωση κώδικα

Σχετικά έγγραφα
Προγραμματισμός ΙΙ (Java) 10. Πολυνηματικές εφαρμογές

Ορισµός Νήµα (thread) είναι µια ακολουθιακή ροή ελέγχου (δηλ. κάτι που έχει αρχή, ακολουθία εντολών και τέλος) σ ένα

Οντοκεντρικός Προγραμματισμός

Τ.Ε.Ι. Μεσολογγίου, Τµήµα τηλεπικοινωνιακών Συστημάτων & Δικτύων

Διάλεξη Εισαγωγή στη Java, Μέρος Γ

Το παρακάτω πρόγραμμα ορίζει δυο κλάσεις την SimpleThread και την TwoThreadsTest:

ΠΑΝΕΠΙΣΤΗΜΙΟ ΚΥΠΡΟΥ - ΤΜΗΜΑ ΠΛΗΡΟΦΟΡΙΚΗΣ ΕΠΛ 133: ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΕΦΗΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΣ ΕΡΓΑΣΤΗΡΙΟ 3 Javadoc Tutorial

Καρακασίδης Αλέξανδρος Καστίδου Γεωργία Παπαφώτη Μαρία Πέτσιος Κων/νος Στέφανος Σαλτέας Καλογεράς Παναγιώτης. Threads in Java ΝΗΜΑΤΑ ΣΤΗ JAVA

Νήµαταστην Java. Συγχρονισµός νηµάτων Επικοινωνία νηµάτων Εκτελέσιµα αντικείµενα Νήµατα δαίµονες Οµάδες νηµάτων. Κατανεµηµένα Συστήµατα 11-1

Διδάσκων: Παναγιώτης Ανδρέου

Κατανεμημένα Συστήματα: Θεωρία και Προγραμματισμός. Ενότητα # 8: Ταυτοχρονισμός και νήματα Διδάσκων: Γεώργιος Ξυλωμένος Τμήμα: Πληροφορικής

11α Κατασκευαστικά πρότυπα σχεδίασης

Εισαγωγή στην Java. Module 9: Threads. Prepared by Chris Panayiotou for EPL /03/2004

14 Πρότυπα Σχεδίασης συνέχεια

13. Νήματα Νήματα και χρήση νημάτων στη Java Τι είναι τα νήματα; Τρία μέρη ενός νήματος

Αντικειμενοστρεφής Προγραμματισμός

Κατασκευαστές. Μέθοδοι Κατασκευής (Constructors).

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

Κινητά και Διάχυτα Συστήματα. Ενότητα # 3: Νήματα και ταυτοχρονισμός Διδάσκων: Γεώργιος Ξυλωμένος Τμήμα: Πληροφορικής

Το πρόγραμμα HelloWorld.java. HelloWorld. Κλάσεις και Αντικείμενα (2) Ορισμός μιας Κλάσης (1) Παύλος Εφραιμίδης pefraimi <at> ee.duth.

Ειδικά Θέματα Προγραμματισμού

Εκφωνήσεις ασκήσεων εργαστηρίου 2 (java threads)

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Αντικείμενα ως ορίσματα

Εισαγωγή στον Αντικειμενοστρεφή Προγραμματισμό Διάλεξη #2

Εισαγωγή στον Προγραµµατισµό, Αντώνιος Συµβώνης, ΣΕΜΦΕ, ΕΜΠ,, Slide 6

Κλάσεις στη Java. Παύλος Εφραιμίδης. Java Κλάσεις στη Java 1

Κλάσεις στη Java. Στοίβα - Stack. Δήλωση της κλάσης. ΗκλάσηVector της Java. Ηκλάση Stack

Κεφάλαιο 1. Νήματα (Threads). Time Sharing

Αντικειµενοστρεφής Προγραµµατισµός

Διδάσκων: Παναγιώτης Ανδρέου

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Μνήμης Αντικείμενα ως ορίσματα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Αναφορές

Κατανεμημένα Συστήματα

Εισαγωγή στη γλώσσα προγραμματισμού Java 69

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα με πίνακες. Constructors. Υλοποίηση Στοίβας

Πολυνηµατικές εφαρµογές σε Java

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Constructors, equals, tostring

Διεργασίες (μοντέλο μνήμης & εκτέλεσης) Προγραμματισμός II 1

ΠΛΗΡΟΦΟΡΙΚΗ ΙΙ (JAVA) 11/3/2008

Εισαγωγή στη γλώσσα προγραμματισμού JAVA. Δομές Δεδομένων Διδάσκων: Π.Α. Μήτκας Τομέας Ηλεκτρονικής και Υπολογιστών

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι

Προγραµµατισµός ΙΙ. Ηγλώσσααντικειµενοστραφούς. ιδάσκων ηµήτριος Κατσαρός, Τµ. Μηχανικών Η/Υ, Τηλεπικοινωνιών & ικτύων Πανεπιστήµιο Θεσσαλίας

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός Αναφορές-Παράμετροι

HelloWorld. Παύλος Εφραιμίδης. Java Το πρόγραμμα HelloWorld 1

Αρχές Τεχνολογίας Λογισμικού Εργαστήριο

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Constructors Υπερφόρτωση Αντικείμενα ως παράμετροι

Αντικειμενοστρεφής Προγραμματισμός

Κληρονομικότητα. Παύλος Εφραιμίδης pefraimi <at> ee.duth.gr. Java Κληρονομικότητα 1

Εισαγωγικά & Βασικές Έννοιες

Βασικές Έννοιες Πρ Ταο υγρ τόα χ μ ρ μ ο α ν τισμ ος Π ό ρ ςο ΙΙΙ γραμματισμός 1

άσκηση Hide UI Elements 7.2 Try and Catch

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Πίνακες Κλάσεις και Αντικείμενα

Τεχνολογία Λογισμικού

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Constructors

Εισαγωγικά & Βασικές Έννοιες

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Υπερφόρτωση Αντικείμενα σαν ορίσματα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα ως ορίσματα

API: Applications Programming Interface

Εισαγωγή εκτελέσιμου κώδικα σε διεργασίες

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι

Αντικειμενοστραφής Προγραμματισμός I (5 ο εξ) Εργαστήριο #2 ο : Ανατομία προγραμμάτων εφαρμογών, η

8. Μέθοδοι (Methods)

Δομές Δεδομένων - Εργαστήριο 2. Λίστες

08 Πολυνηματικός προγραμματισμός στο JVM

Κλάσεις και Αντικείµενα

Αντικειμενοστρεφής Προγραμματισμός

Αντικειμενοστραφής Προγραμματισμός I(5 ο εξ) Εργαστήριο #2 ο : Ανατομία προγραμμάτων εφαρμογών, η

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εισαγωγή στη Java

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Δημιουργία Κλάσεων και Αντικειμένων Constructors

2 Ορισμός Κλάσεων. Παράδειγμα: Μηχανή για Εισιτήρια. Δομή μιας Κλάσης. Ο Σκελετός της Κλάσης για τη Μηχανή. Ορισμός Πεδίων 4/3/2008

Εργαστήριο ΔΙΕΡΓΑΣΙΕΣ - ΔΙΑΧΕΙΡΙΣΗ

Διάλεξη 5: Κλάσεις και Αντικείμενα. Διδάσκων: Παναγιώτης Ανδρέου

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα ως ορίσματα Εισαγωγή στις αναφορές

$./jms console -w <jms in> -r <jms out> -o <operations file> namedpipe. (standard input).

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Δημιουργία Κλάσεων και Αντικειμένων

6. Εξαιρέσεις στη γλώσσα Java

Για την υλοποίηση του προγράμματος χρειάζονται 3 βασικές κλάσεις.

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αντικείμενα με πίνακες. Constructors. Υλοποίηση Στοίβας

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Αναφορές Στοίβα και Σωρός μνήμης Αντικείμενα παράμετροι String Interning

Περιεχόµενα. 1 Εισαγωγή στις οµές εδοµένων 3. 2 Στοίβα (Stack) 5

2.1 Αντικειµενοστρεφής προγραµµατισµός

Αντικειμενοστρεφής Προγραμματισμός

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Δημιουργώντας δικές μας Κλάσεις και Αντικείμενα

Προγραμματισμός Ταυτόχρονος Προγραμματισμός

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Σύνθεση αντικειμένων

Υποστήριξη Λ.Σ. ΜΥΥ-106 Εισαγωγή στους Η/Υ και στην Πληροφορική

Αντικειμενοστρεφής Προγραμματισμός

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Υπάρχουσες κλάσεις και αντικείμενα στην Java Strings Wrapper Classes Δομές

Λειτουργικά Συστήματα (Λ/Σ)

Κλάσεις και αντικείμενα #include <iostream.h<

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι

Προγραµµατισµός ΙΙ. Ηγλώσσααντικειµενοστραφούς. Εισαγωγή στα Java Νήµατα. Τι είναι ένα thread (1/9)

Εργαστήριο Ανάπτυξης Εφαρμογών Βάσεων Δεδομένων. Εξάμηνο 7 ο

Διάλεξη 06: Συνδεδεμένες Λίστες & Εφαρμογές Στοιβών και Ουρών

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Κλάσεις και Αντικείμενα Μέθοδοι

Εαρινό. Ύλη εργαστηρίου, Ασκήσεις Java

ΚΑΤΑΝΕΜΗΜΕΝΟ ΣΥΣΤΗΜΑ ΔΙΑΧΕΙΡΙΣΗΣ ΣΥΣΚΕΥΩΝ ΑΣΗΜΑΚΟΠΟΥΛΟΣ ΣΩΤΗΡΗΣ ΑΜ : 3021

Λειτουργικά Συστήματα. Τ.Ε.Ι. Ιονίων Νήσων Σχολή Διοίκησης και Οικονομίας - Λευκάδα

ΤΕΧΝΙΚΕΣ ΑΝΤΙΚΕΙΜΕΝΟΣΤΡΑΦΟΥΣ ΠΡΟΓΡΑΜΜΑΤΙΣΜΟΥ. Εξαιρέσεις

Transcript:

Προγραμματισμός ΙΙ (Java) 10. Πολυνηματικές εφαρμογές Τεκμηρίωση κώδικα

Multithreading Μulti-processing Πολλές διεργασίες ταυτόχρονα Κάθε διεργασία έχει το δικό της χώρο μνήμης ή ενδέχεται όλες να μοιράζονται και κάποιο χώρο μνήμης Ουσιαστικά μία διεργασία εκτελείται κάθε φορά Το λειτουργικό αναλαμβάνει τη διαχείριση Multithreading Multiple points of execution (threads) within the same memory space 2

Threads - Νήματα Τα threads επιτρέπουν εργασίες να τρέχουν παράλληλα με την κύρια εφαρμογή Είναι διεργασίες που τρέχουν στον ίδιο χώρο διευθύνσεων: μοιράζονται τις μεταβλητές στιγμιοτύπων, αλλά διατηρούν και τοπικές μεταβλητές Χρησιμοποιούνται από το JVM σε συγκεκριμένες περιπτώσεις Όταν φορτώνουμε μια εικόνα ή ένα ήχο μέσα από ένα applet. Όταν καλούμε την update του αντικειμένου graphics Μπορούμε να δηλώσουμε και να χρησιμοποιήσουμε δικά μας νήματα.

Γιατί χρειάζομαι threads Single threaded application: Ένα νήμα κάνει τα πάντα Αν υπάρχουν ενέργειες να εκτελεστούν, θα περιμένουν τη σειρά τους Αν μια ενέργεια θέλει χρόνο για να ολοκληρωθεί, η εφαρμογή θα φαίνεται ότι έχει κολλήσει Multithreaded application: Ένα νήμα για κάθε εργασία Αν ένα νήμα έχει αναλάβει μια αργή ενέργεια, τα υπόλοιπα νήματα θα συνεχίσουν να εκτελούνται Αν η εφαρμογή τρέχει σε σύστημα με πολλούς επεξεργαστές, το λειτουργικό θα στείλει κάθε νήμα σε άλλο επεξεργαστή. 4

Πότε χρειάζομαι threads Όταν η εφαρμογή μου έχει GUI Τα νήματα που αφορούν το GUI διαχειρίζονται τις ενέργειες του χρήστη και αναθέτουν τις εργασίες σε άλλα νήματα Το GUI συνεχίζει να αποκρίνεται στις ενέργειες του χρήστη ακόμη κι αν τρέχουν άλλα νήματα Όταν η εφαρμογή μου πρέπει να αποκρίνεται ασύγχρονα (π.χ. Network based applications) Τα δεδομένα που έρχονται από το δίκτυο μπορεί να έρχονται χωρίς ομαλή ροή Ένα νήμα μπορεί να ελέγχει την πόρτα εισόδου δεδομένων Όποτε έρθουν δεδομένα το νήμα ολοκληρώνει τη διαχείρισή τους ή την αναθέτει σε άλλο νήμα Η εφαρμογή μας τρέχει σε άλλο νήμα 5

Πώς λειτουργεί ο μηχανισμός; Κάθε νήμα έχει το δικό του χώρο (virtual registers και calling stack) Ο "scheduler" αποφασίζει ποιο νήμα εκτελείται και πότε Το VM μπορεί να έχει το δικό του scheduler ή να χρησιμοποιεί το scheduler του λειτουργικού (το JVM έχει δικό του) Ο scheduler έχει μια λίστα με τα threads που είναι έτοιμα να τρέξουν (run queue) και μια λίστα με τα threads που περιμένου είσοδο (wait queue) Κάθε νήμα έχει μια προτεραιότητα. Τα threads υψηλής προτεραιότητας επιλέγονται κάθε φορά από την run queue Δεν μπορούμε να υποθέσουμε από πριν με ποια σειρά θα χρονοπρογραμματιστούν τα threads. 6

Καταστάσεις ενός thread Thread created New start() Ready yield(), or time out run() join() Running run() returns Finished Target finished interrupt() sleep() wait() Wait for target to finish Wait for time out Wait to be notified Blocked Time out notify() or notifyall() Interrupted()

Πώς τρέχει ένα thread Ξεκινά με τη μέθοδο run() που περιέχει το βασικό σύνολο εντολών του νήματος Ενεργοποιείται με το start() Τερματίζει όταν ολοκληρωθεί η run() Αν θέλουμε να μην ολοκληρωθεί το νήμα, πρέπει να μπλοκάρουμε τη run (π.χ. με endless loop) Ένα thread καλεί κάποιο άλλο με την κλήση της start() Thread1 start() Thread Object run() Thread2 8

Ένα Thread για κάθε Task Ένα Thread μπορεί να είναι αντικείμενο της κλάσης Thread ή δικών μας κλάσεων που κληρονομούν τη Thread Συχνά οι δικές μας κλάσεις μπορεί να έχουν δική τους κληρονομικότητα, και ταυτόχρονα να θέλουμε να είναι threads Τότε χρησιμοποιούμε το Runnable interface Ένα interface με μοναδική μέθοδο την run() Χρειαζόμαστε και κάποιον (ένα dummy Thread object) να φτιάξει και να ξεκινήσει το νήμα μας 9

Τρόποι δήλωσης (1/2) Επέκταση της Thread public class HelloThread extends Thread { public void run() { System.out.println("Hello from a thread!"); public static void main(string args[]) { (new HelloThread()).start();

Τρόποι δήλωσης (2/2) Υλοποίηση της Runnable 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(); Thread1 start() Thread2 Thread Object run() Runnable Object run()

Μέθοδοι Thread.yield(): όποτε καλείται δίνει προτεραιότητα στα υπόλοιπα threads εις βάρος του τρέχοντος. Thread.sleep(long x): σταματά προσωρινά (για x milliseconds) την εκτέλεση του νήματος final void otherthread.join(): διακόπτει το τρέχον νήμα μέχρι να τελειώσει το otherthread isalive(): επιστρέφει true για Ready, Blocked, or Running state interrupt(): αν το thread είναι Ready or Running, σταματά. Αν είναι blocked ξυπνά και γίνεται Ready ενώ πετά μια java.io.interruptedexception isinterrupt(): ελέγχει αν το νήμα εξακολουθεί να είναι σταματημένο ή ξαναξεκίνησε

Πώς τερματίζω ένα thread Στη Java 1.1. η κλάση Thread είχε μέθοδο stop() Ένα thread σταματούσε ένα άλλο thread καλώντας τη stop() Είχε και suspend() και resume() Αυτό όμως οδηγούσε σε αμοιβαίους αποκλεισμούς (deadlocks) Πλέον δε χρησιμοποιούνται (deprecated) Αν θέλουμε να τερματίσουμε το thread περιμένουμε να τελειώσει η run Αν θέσω ένα boolean γνώρισμα στο thread και φροντίζω να ελέγχω την τιμή του εντός της run, μπορώ να ελέγξω πότε θα τελειώσει Μέσω μιας μεθόδου set αλλάζω την τιμή στο γνώρισμα (από άλλο νήμα που τρέχει) και τερματίζω τη run() βγαίνοντας από το infinite loop 13

Κοινή χρήση; Υπάρχουν θέματα συγχρονισμού (ταυτόχρονης πρόσβασης στον κοινόχρηστο χώρο) που πρέπει να ληφθούν υπόψη. Για να αντιληφθούμε καλύτερα τα νήματα θεωρούμε δύο μόνο αντικείμενα που μοιράζονται τον κοινό χώρο: Το αντικείμενο Thread της Java που ελέγχει το χώρο (ελεγκτής) και ένα αντικείμενο που περιέχει τη μέθοδο που θα εκτελέσουμε παράλληλα (νήμα). Το αντικείμενο νήμα έχει μια μέθοδο run η οποία: πρέπει να είναι public, να μην παίρνει ορίσματα, να μην επιστρέφει τιμές και να μην παράγει εξαιρέσεις. Το αντικείμενο ελεγκτής φτιάχνει το νήμα, το ξεκινά (καλώντας τη run) και το καταστρέφει μόλις τελειώσει.

Δήλωση μιας τάξης νήματος Μια τάξη νήμα υλοποιεί τη διεπαφή Runnable (ορίζει μια μέθοδο run). Περιέχει μια σημαία (flag) επιτυχούς ολοκλήρωσης της διεργασίας. Μέσα στη run υλοποιεί την παράλληλη διεργασία και στο τέλος της ενημερώνει τη σημαία. class Animation implements Runnable { boolean finished; public void run( ) {... finished=true;

Έλεγχος ενός νήματος Στην κυρίως εφαρμογή φτιάχνουμε το αντικείμενο νήμα Animation happy = new Animation(); Φτιάχνουμε το αντικείμενο ελεγκτή και του αναθέτουμε να παρακολουθεί το νήμα Thread mythread = new Thread( happy ); Ο ελεγκτής ξεκινά το νήμα mythread.start( ); Η τελευταία εντολή εκτελεί τη run του αντικειμένου happy (νήμα) Για να ξεκινήσουμε ένα δεύτερο νήμα (οποιασδήποτε τάξης) ο ελεγκτής συνδέεται με αυτό και το ξεκινά mythread = new Thread( new anotherthreadclass() ); mythread.start( );

Παύση και επανεκκίνηση νήματος Η μέθοδος sleep( ) σταματά το νήμα για κάποια milliseconds, δημιουργώντας ένα InterruptedException αν το νήμα είναι ήδη σταματημένο Η μέθοδος interrupt( ) ξαναξεκινά ένα νήμα που ήταν αδρανές try { sleep( 500 ); // περιμένει 0,5" catch ( InterruptedException e ) { // αν κάποιος καλέσει την interrupt για το νήμα Οι μέθοδοι wait() και notify( ) συντονίζουν την εκτέλεση δύο ή περισσοτέρων νημάτων

Τερματισμός του Thread Πρέπει να μπλοκάρουμε τη run() σε ένα loop Πρέπει να φροντίσουμε να μπορεί να επιστρέψει βγαίνοντας από το loop public void stopthread(){ this.stopthread=true; public void run( ) {. while (true) { if (stopthread) return;

Παράδειγμα Δημιουργήστε ένα GUI με 3 buttons και ένα text field Με το start: θα ξεκινά ένα thread που θα τυπώνει την τρέχουσα ώρα και ημερομηνία στο text field κάθε 1 sec. Με το stop: το thread θα σταματά Με το reset: θα καθαρίζει το text field

Ταυτόχρονη πρόσβαση σε δεδομένα Δύο threads επιχειρούν να ενημερώσουν τα ίδια δεδομένα (π.χ. να προσθέσουν/διαγράψουν/διαβάσουν αντικείμενα από μια συλλογή) Το τελικό αποτέλεσμα εξαρτάται απόλυτα από τον scheduler και δεν μπορούμε να το προκαθορίσουμε Όσο το ένα thread γράφει κάτι στα δεδομένα, μπορεί να τα «κλειδώσει» μέχρι να τελειώσει Κανείς εκτός από το thread δεν μπορεί να δει τα κλειδωμένα δεδομένα Ο μηχανισμός αυτός στην Java λέγεται synchronization 20

Συγχρονισμός νημάτων Έστω ένας τραπεζικός λογαριασμός με ένα αρχικό ποσό, ένα νήμα που κάνει κατάθεση και δύο νήματα που κάνουν ανάληψη Parent public class SavingsAccount { private float balance; public synchronized void withdraw(float anamount) { if ((anamount>0.0) && (anamount<=balance)) balance = balance - anamount; public synchronized void deposit(float anamount) { if (anamount>0.0) balance = balance + anamount; 1000 SavingsAccount Child1 Child2

Παράδειγμα Ο Parent καταθέτει χρήματα κάθε 5" καλώντας την deposit Τα Child αφαιρούν χρήματα κάθε 3" καλώντας την withdraw class Parent implements Runnable { SavingsAccount account; String name; boolean bankrupted = false; public Parent(String n, SavingsAccount s) { this.name = n; this.account = s; public void run() { while (true) { try { Thread.sleep(5000); catch (InterruptedException ex) { account.deposit(this.name, 1000); if (bankrupted) { return; class Child implements Runnable { SavingsAccount account; String name; boolean foundajob= false; public Child(String n, SavingsAccount s) { this.name = n; this.account = s; public void run() { while (true) { try { Thread.sleep(3000); catch (InterruptedException ex) { account.withdraw(this.name, 200); if (foundajob) { return;

Η main Φτιάχνει το λογαριασμό τον Parent τα Child Ξεκινά τα νήματα

Συγχρονισμένες μέθοδοι

Συνεπώς Έχουμε withdraw κλήσεις από τα Child που εξυπηρετούνται όσο υπάρχει υπόλοιπο Μόλις αδειάσει ο λογαριασμός η τελευταία κλήση της withdraw παγώνει (wait) Μια κλήση της deposit από τον parent καλεί τη notify και ξεπαγώνει τη συγχρονισμένη μέθοδο withdraw Πότε παγώνει η deposit και πως βγαίνουμε από την κατάσταση αυτή;

Thread Pools Αν ξεκινάμε ένα thread για κάθε task είναι δαπανηρό. Θέλουμε μια δεξαμενή με threads, που να μας δίνει ένα thread αν αυτό έχει τελειώσει την προηγούμενη εργασία Η υλοποίηση προσφέρεται μέσα από το Executor interface το οποίο ελέγχει τα Runnable αντικείμενα σε ένα thread pool Το ExecutorService είναι ένα subinterface του Executor «interface» java.util.concurrent.executor +execute(runnable object): void Executes the runnable task. «interface» java.util.concurrent.executorservice +shutdown(): void +shutdownnow(): List<Runnable> +isshutdown(): boolean +isterminated(): boolean Shuts down the executor, but allows the tasks in the executor to complete. Once shutdown, it cannot accept new tasks. Shuts down the executor immediately even though there are unfinished threads in the pool. Returns a list of unfinished tasks. Returns true if the executor has been shutdown. Returns true if all tasks in the pool are terminated. 26

Δημιουργία εκτελεστή (Executor) Φτιάχνουμε Executor αντικείμενα μέσα από static methods της Executors java.util.concurrent.executors +newfixedthreadpool(numberofthreads: int): ExecutorService +newcachedthreadpool(): ExecutorService Creates a thread pool with a fixed number of threads executing concurrently. A thread may be reused to execute another task after its current task is finished. Creates a thread pool that creates new threads as needed, but will reuse previously constructed threads when they are available. 27

ExecutorService executor = Executors.newFixedThreadPool(5); Runnable worker = new MyClassThatImplementsRunnable(); executor.execute(worker); public class MyClassThatImplementsRunnable implements Runnable { public void run() { System.out.println(Thread.currentThread().getName() + " Start."); processcommand(); System.out.println(Thread.currentThread().getName() + " End."); 28

Τεκμηρίωση κώδικα javadoc 29

Σχόλια (Comments) Σχόλια είναι σημειώσεις σε φυσική γλώσσα και όχι source code. Τα Comments χρησιμοποιούνται για να: Τεκμηριώνουμε: τον σκοπό και τους στόχους του προγράμματος, τον author, ιστορικά στοιχεία για τις αναθεωρημένες εκδώσεις του code (revision history), copyright notices, κτλ. Περιγράφουμε: fields, constructors, και methods Την επεξήγηση μη καθαρών σημείων του code Προσωρινός σχολιασμός μέρους του code, σαν υπενθύμιση για μελλοντική χρήση

Μορφές Σχολίων Ένα block σχόλιο γράφεται ανάμεσα στα σύμβολα /* και */. Για παράδειγμα: /* Exercise 5-2 for Java Methods Author: Miss Brace Date: 3/5/2010 Rev. 1.0 */ Ένα single-line σχόλιο γράφεται μετά από το σύμβολο // μέχρι το τέλος της γραμμής. Για παράδειγμα: wt *= 2.2046; // Convert to kilograms

Σχόλια Τεκμηρίωσης Μπορούμε να χρησιμοποιήσουμε το special utility program javadoc για να παράξουμε αυτόματα τεκμηρίωση του source code μας σε HTML format. Τέτοιας μορφής σχόλια πρέπει να προηγούνται των: classes, methods, ή fields Μπορούν να χρησιμοποιηθούν special javadoc tags: @param περιγράφει τις παραμέτρους μιας μεθόδου (method) @return - περιγράφει την τιμή που επιστρέφονται από μια μέθοδο (method s return value)

javadoc Comments (συνέχ.) /** δείχνει ένα javadoc comment /** * Returns total sales from all vendors; * sets <code>totalsales</code> * to 0. * * @return total amount of sales from all vendors */ Μπορεί να χρησιμοποιεί HTML tags Common style

Δομή σχολίων μεθόδου Περιγραφή Ετικέτες Προαπαιτούμενα Συνέπειες

Ετικέτες Μεθόδων @see @since @deprecated @param @return @throws / @exception {@link {@linkplain {@inheritdoc {@docroot

Παράδειγμα /** * Sample.java a class that demonstrates the use of javadoc * comments. * @author Ruth Dannenfelser * @version 2.0 * @see Sample2 */ public class Sample extends Sample2 { public String words; /** * Retrieve the value of words. * @return String data type. */ public String getwords() { return words; /** * Set the value of words. * @param somewords A variable of type String. */ public void setwords(string somewords) { words = newwords;

Δημιουργία τεκμηρίωσης javadoc d doc src/package/*.java 37