Analisi e progettazione concorrente (esempi con Java) Analisi e progettazione concorrente. Task e thread

Dimensione: px
Iniziare la visualizzazioe della pagina:

Download "Analisi e progettazione concorrente (esempi con Java) Analisi e progettazione concorrente. Task e thread"

Transcript

1 Bibliorafia e riferimenti,6 PRG % &RUVR GL,QJHJQHULD GHO 6RIWZDUH 80/ Analisi e proettazione concorrente (esempi con Java) - Hassan Gomaa: Desinin concurrent distributed and real time applications with UML, Addison Wesley Reference manual UML.4 - JDK.4 DOC ( Sun Microsystems ) Renato Conte - Concorrenza e Studio di caso parte - - Renato Conte - Concorrenza e Studio di caso parte - - Task e thread Analisi e proettazione concorrente elementi di prorammazione concorrente task heavyweiht process: scambio di contesto oneroso possiede e controlla il proprio spazio di memoria lihtweiht process: thread scambio di contesto essenziale condivide spazi di memoria con heavyweiht process In questo modulo, le considerazioni di analisi fatte con thread di applicano anche ai task e viceversa Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 4 -

2 Thread Multithreadin / multitaskin [cond] A C [not cond] B Un thread rappresenta l esecuzione sequenziale di istruzioni ( o di attività ), molte volte in un contesto concorrente. Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Oetti attivi e passivi Oetti attivi e passivi Oetti passivi: aspettano un messaio per invocare una operazione, non fanno partire mai delle attività. Non hanno thread di controllo. Oetti attivi: sono task concorrenti. Hanno il loro thread di controllo (hanno la propria vita ). Possono far partire delle azioni che coinvolono altri oetti. Una operazione di un oetto passivo, una volta invocato da un oetto attivo, va in esecuzione in un thread di controllo dell oetto attivo. :oetto passivo :oetto attivo Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 8 -

3 Oetti attivi e passivi () Problemi in thread concorrenti Oetti contemporaneamente attivi e passivi : in Java, e possibile per un oetto incapsulare un thread, ma anche avere operazioni (metodi) che possono essere invocate da altri thread. Mutua esclusione ( su risorse condivise ) (es. uso di semafori ) Sincronizzazione (es.con senali asincroni ) Produttore consumatore (es. con monitor ) Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Mutua esclusione Sincronizzazione con messai con o senza comunicazione dati aquire (Semaforo); // oppure wait ( S ) timerevent X.usoDellaRisorsaCondivisa( ); // sezione critica release (Semaforo); // oppure sinal( S ) external event : sender internal event : receiver sinal( event ) wait( event ) Dijkstra: P(semaforo) SezioneCritica V(semaforo). send receive Renato Conte - Concorrenza e Studio di caso parte - - Renato Conte - Concorrenza e Studio di caso parte - -

4 Sincronizzazione con messai send ( in dest, in ms) il processo inviante e bloccato fino a che il ms è ricevuto il processo inviante invia il ms e continua receive( in sor, out ms) se il ms è ià stato inviato, viene acquisito e l esecuzione continua se il ms non è ancora stato inviato: il proc. è bloccato in attesa; il proc. continua perdendo il ms. Blokin send - blokin receive: tiht synchronization o rendezvous Nonblokin send - blokin receive: la più comune Nonblokin send - Nonblokin receive. dest/sor: proc. mailbox Es. sincronizzazione event sinal senza comunicazione dati (senza conferma => canale asincrono) pick: robot while( lavorodafare ) preparapezzo( ) posizionapezzo( ) sinal( pezzopronto ) wait( pezzolavorato ) prelevapezzo( ) endwhile pezzopronto pezzolavorato drill: robot while( lavorodafare ) wait( pezzopronto ) lavorapezzo( ) sinal( pezzolavorato) endwhile... quando la situazione è più complessa pericolo di deadlok Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Tihtly coupled messae communication whith replay (con conferma => canale sincrono) Produttore consumatore con monitor telecamera IDmessae replay_fatto : robot write( in dato ) :Produttore while( lavorodafare ) endwhile identificapezzo( ) send ( IDmessae ) // attesa conferma wait ( replay_fatto ) while( lavorodafare ) endwhile receive( IDmessae ) * lavorapezzo(... ) send( replay_fatto ) * puo essere la receive stessa che invia conferma di ricevuto «monitor - object» :Buffer :Consumatore read( out dato ) Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 6 -

5 Inter task communication con monitor queue connector Inter task communication con monitor queue connector send( in messaio ) :Produttore «monitor - object» :MessaeQueue :Consumatore receive( out messaio ) class MessaeQueue: Monitor coda: Tcoda public send( in messaio ) while ( coda.codapiena( ) ) wait deposita messaio in coda sinal end send public receive( out messaio ) while ( coda.codavuota( ) ) wait preleva messaio dalla coda sinal end send endclass MessaeQueue Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Thread java: stati Runnable Thread e sincronizzazione in Java start( ) new Thread Standby [ termina metodo run ] Dead Ready scheduler Runnin [preemption] [ sleep end ], [ join done ], interrupt( ) Halted sleep( lon ), join(. ) wait( ) [ block on synchr.] Blocked in wait notify( ), notifyall( ) interrupt( ) Blocked in lock [ not block] Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 0 -

6 Thread java: metodi () Thread java: metodi () join( ) il thread corrente aspetta che il thread, sul quale la join è invocata, termini join( lon t ) aspetta per t millisecondi che il thread, sul quale la join è invocata, termini new AltroThread azionivarie( ) run( ) di tt azionivarie( ) // questo è un metodo di un thread xx public void provajoin( ) AltroThread tt = new AltroThread( ); tt.start( ); // fork azionivarie( ); // thread xx in parallelo con tt try tt.join( ); // thread xx aspetta tt catch( interruptexception e) azionivarie( ); // thread xx continua senza tt // provajoin Renato Conte - Concorrenza e Studio di caso parte - - Renato Conte - Concorrenza e Studio di caso parte - - Thread java: metodi () Thread java: metodi (3) static sleep( lon t ) ; // aspetta t millisecondi wait( ) aspetta finche un altro thread invochi una notify( ), od una notifyall( ) sono metodi invocati su un oetto rendezvous da metodi synchronized wait( lon t ) taxista cliente e taxi Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 4 -

7 interrupt( ); // interrompe il thread Thread java: metodi (4) class SimpleThread extends Thread public SimpleThread( Strin str ) super(str); // nome del thread public void run( ) // override il metodo vuoto for (int i = 0; i < 0; i++) System.out.println(i + " " + etname( )); try sleep((lon)(math.random( ) * 00)); catch (InterruptedException e) //for System.out.println("DONE! " + etname()); //run //SimpleThread ( Java ) Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte public class TwoThreadsDemo public static void main( Strin[ ] ars ) new SimpleThread( Pippo").start( ); new SimpleThread( Pluto").start( ); //main 0 Pippo 0 Pluto Pippo Pippo Pluto 3 Pippo Pluto ( Java ) ( Java ) thread e interface runable public class InterfThread extends ImportantClass implements Runnable public void run( )... // azioni varie new Thread( new InterfThread ( ) ).start( ); 3 Pluto... Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 8 -

8 :Produttore *[..n]: put( dato ) Produttore consumatore in Java :Consumatore «monitor» :Buffer *[..n]: dato:=et( ) Produttore consumatore in Java () public class Produttore extends Thread private Buffer buffer; // reference private int pin; public Produttore ( Buffer c, int number ) buffer = c; // reference this. pin = pin; public void run( ) for (int i = 0; i < 0; i++) buffer.put(i); System.out.println("Prod. #" + pin + " put: " + i); /*... sleep statement */ //for // Produttore Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Produttore consumatore in Java () Produttore consumatore in Java (3) public class Consumatore extends Thread private Buffer buffer; // reference private int pin; public Consumatore ( Buffer c, int pin) buffer = c; // reference this. pin = pin; public class Buffer static final int N = 0; private int = 0, p= 0; private int vettc [ ]= new int[n]; public synchronized int et( )... accesso mutuamente esclusivo sull oetto Buffer ai metodi synchronized public void run( ) int value; for ( int i = 0; i < 0; i++ ) // non eleante: si prevedono due produttori da 0 value = buffer.et(); System.out.println("Consumer #" + pin + " ot: " + value); //for //run // Consumatore // Buffer public synchronized void put( int value )... N- 0 Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte - 3 -

9 Produttore consumatore in Java (4) Produttore consumatore in Java (5) public class ProduttoreConsumatoreTest public static void main( Strin[] ars ) Buffer c = new Buffer( ); Produttore p = new Produttore (c, ); Produttore p = new Produttore (c, ); Consumatore c = new Consumatore (c, ); //main p.start( ); p.start( ); c.start(); // ProducerConsumerTest public synchronized int et( ) while (==p ) // vuoto try wait( ); // aspetta che un Produttore inserisca un valore catch (InterruptedException e) //et notifyall(); // svelia tutti il thread che attendono sul buffer int x= vettc[]; =(+)%N; return x; N- 0 p Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Produttore consumatore in Java (6) public synchronized void put( int value ) while ( (p+) % N== ) // pieno try wait( ); // aspetta che un Consum. prelevi catch (InterruptedException e) vettc[p] = value; p= (p+) % N; notifyall(); // notifica che c è un valore disponibile //put Produttore consumatore in Java (7) N- 0 p 3 dato = et( ); N- 0 p Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte

10 Produttore consumatore in Java (9x) Produttore consumatore in Java (0x) N- 0 put( dato ); N- 0 3 p 3 put( dato ); dato = et( ); p dato = et( ); Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Modello statico del contesto: classi external, system «external I/O dev.» Card reader Studio di caso: ATM (alcuni cenni) «external Output dev.» Stampante..* «system» Bankin System «external Output dev.» Distrib.contanti Cliente ATM Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte

11 Cliente ATM ATM: Use case sottosistemi Client / Server ATM Client Subsystem Client Validazione PIN <<include>> Client TrasferimentoFondi <<include>> <<include>> ATM Server Subsystem Server Validazione PIN Server TrasferimentoFondi :Cliente ATM display info Diaramma di collaborazione Bankin system diaramma concorrente ed ad alto livello con oetti attivi IN «system» :Bankin System «Client sub system» :ATM client Transazione ATM Queue ResponsoDellaBanca «Server subsystem» :BankServer operatore ATM Client PrelievoContanti Client ListaMovimenti Aiuni Contante <<include>> <<include>> Server ListaMovimenti Server PrelievoContanti «external» :Stampante CardReaderIN «external» :Card reader CardReaderOUT «external» :Distributore contanti Startup Shutdown Renato Conte - Concorrenza e Studio di caso parte Renato Conte - Concorrenza e Studio di caso parte Diaramma di collaborazione BankServer subsystem «Client sub system» :ATM client Transazione ATM «Server subsystem» :BankServer Queue «coordinatore» :A ResponsoDellaBanca «business loic» :B «business loic» :C «data base» :D Renato Conte - Concorrenza e Studio di caso parte

Analisi e progettazione concorrente. Studio di caso: ATM (seconda parte) Real Time: concetti e termini. Analisi e progettazione concorrente

Analisi e progettazione concorrente. Studio di caso: ATM (seconda parte) Real Time: concetti e termini. Analisi e progettazione concorrente Bibliografia e riferimenti,6 PRG % &RUVR GL,QJHJQHULD GHO 6RIWZDUH 80/ Analisi e progettazione concorrente Studio di caso: ATM (seconda parte) Real Time: concetti e termini - Hassan Gomaa: Designing concurrent

Dettagli

Analisi e progettazione concorrente

Analisi e progettazione concorrente Task e thread Analisi e roettazione concorrente (esemi con Java) task heavyweiht rocess: scambio di contesto oneroso ossiede e controlla il rorio sazio di memoria lihtweiht rocess: thread scambio di contesto

Dettagli

Programmazione concorrente con il linguaggio Java

Programmazione concorrente con il linguaggio Java Programmazione concorrente con il linguaggio Java Thread, Mutua Esclusione e Sincronizzazione Alcuni aspetti architetturali e di prestazioni Concetto di thread Un thread è un flusso di esecuzione indipendente

Dettagli

Esercitazione 2: Java Thread

Esercitazione 2: Java Thread Esercitazione 2: Java Thread Thread Un thread è un singolo flusso sequenziale di controllo all interno di un processo Un thread (o processo leggero) è un unità di esecuzione che condivide codice e dati

Dettagli

Esercitazione 2: Java Thread. Java Thread. Java Thread. Un thread:

Esercitazione 2: Java Thread. Java Thread. Java Thread. Un thread: Esercitazione 2: Thread Un thread è un singolo flusso sequenziale di controllo all interno di un processo Un thread (o processo leggero) è un unità di esecuzione che condivide codice e dati con altri thread

Dettagli

Come si crea un thread. Thread in Java. Altro modo di creare un thread. Come si crea un thread

Come si crea un thread. Thread in Java. Altro modo di creare un thread. Come si crea un thread Thread in Java Come si crea un thread Una applicazione Java che usa i thread può eseguire più attività contemporaneamente. Esempio: aggiornare l'informazione grafica sullo schermo e accedere alla rete.

Dettagli

Java Thread. Thread. Un thread

Java Thread. Thread. Un thread Java Thread Thread Un thread è un singolo flusso sequenziale di controllo all interno di un processo Un thread (o processo leggero) è un unità di esecuzione che condivide codice e dati con altri thread

Dettagli

Java Virtual Machine. Indipendenza di java dalla macchina ospite. I threads in Java

Java Virtual Machine. Indipendenza di java dalla macchina ospite. I threads in Java programmi sorgente: files.java compilatore Indipendenza di java dalla macchina ospite Programmi java Programmi java Programmi java files.class bytecode linker/loader bytecode bytecode Java API files.class

Dettagli

Studio di caso: Bancomat Automated Teller Machine

Studio di caso: Bancomat Automated Teller Machine ,6 PRG % &RUVR GL,QJHJQHULD GHO 6RIWZDUH 80/ Studio di caso: Bancomat Automated Teller Machine (prima parte) Bibliografia: - Hassan Gomaa: Designing concurrent distribuited and real time applications with

Dettagli

Corso sul linguaggio Java

Corso sul linguaggio Java Corso sul linguaggio Java Modulo JAVA9 B3.2 Produttore-consumatore 1 Prerequisiti Elementi di programmazione concorrente Mutua esclusione Produttore-consumatore 2 1 Introduzione In questa Unità vediamo

Dettagli

Multitheading. Corso di Laurea in Informatica. Sperimentazioni di Linguaggi di Programmazione: Paradigmi di Programmazione. a.a.

Multitheading. Corso di Laurea in Informatica. Sperimentazioni di Linguaggi di Programmazione: Paradigmi di Programmazione. a.a. Multitheading Corso di Laurea in Informatica Sperimentazioni di Linguaggi di Programmazione: Paradigmi di Programmazione a.a. 1999/2000 Matteo Baldoni 1 Thread multipli all interno di un Task thread PC

Dettagli

I Thread. un thread è uno stream di esecuzione del programma

I Thread. un thread è uno stream di esecuzione del programma I Thread un thread è uno stream di esecuzione del programma Sistema Operativo e Thread Un processo o thread una successione di operazioni che vengono eseguite dal sistema operativo in modo sequenziale

Dettagli

Problema del buffer limitato. Lorenzo Gallucci

Problema del buffer limitato. Lorenzo Gallucci Problema del buffer limitato Lorenzo Gallucci Buffer limitato Immaginiamo una struttura dati che contiene delle informazioni La struttura può, in ogni momento, avere dello spazio libero oppure no Se vi

Dettagli

Concorrenza e sincronizzazione

Concorrenza e sincronizzazione Concorrenza e sincronizzazione Ingegneria del software Ing. Jody Marca jody.marca@polimi.it Cosa faremo oggi 2 Concorrenza Sincronizzazione Concorrenza 3 Nei programmi Java fino ad ora sviluppati è presente

Dettagli

I Thread. Sistema Operativo e Thread

I Thread. Sistema Operativo e Thread I Thread un thread è uno stream di esecuzione del programma Sistema Operativo e Thread Un processo o thread una successione di operazioni che vengono eseguite dal sistema operativo in modo sequenziale

Dettagli

I Thread in Java. Sistemi Operativi L-A. I threads in Java

I Thread in Java. Sistemi Operativi L-A. I threads in Java I Thread in Java I threads in Java Ogni programma Java contiene almeno un singolo thread, corrispondente all esecuzione del metodo main() sulla JVM. E possibile creare dinamicamente nuovi thread attivando

Dettagli

Corso di Linguaggi di Programmazione

Corso di Linguaggi di Programmazione Corso di Linguaggi di Programmazione Lezione 13 Alberto Ceselli ceselli@dti.unimi.it Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 7 Maggio 2007 Outline Java e C# 1 Java

Dettagli

Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002. Sistemi Operativi Corsi A e B. Esercitazioni 7 e 8

Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002. Sistemi Operativi Corsi A e B. Esercitazioni 7 e 8 Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002 Corsi A e B Esercitazioni 7 e 8 Bounded Buffer con sincronizzazione Java (1) public class BoundedBuffer private

Dettagli

Sincronizzazione dei Thread in Java. Daniela Tibaldi:

Sincronizzazione dei Thread in Java. Daniela Tibaldi: Sincronizzazione dei Thread in Java Daniela Tibaldi: dtibaldi@deis.unibo.it 1) Sottoclasse della classe Thread Thread possiede un metodo run() che la sottoclasse deve ridefinire si crea un istanza della

Dettagli

Sincronizzazione dei Thread in Java

Sincronizzazione dei Thread in Java 1) Sottoclasse della classe Thread Sincronizzazione dei Thread in Java Daniela Tibaldi: dtibaldi@deis.unibo.it Thread possiede un metodo run() che la sottoclasse deve ridefinire si crea un istanza della

Dettagli

Java Threads. esempi

Java Threads. esempi Java Threads esempi Creazione public class ProvaThread { public static void main(string[] args) { Runnable r = new MyRunnable(); Thread t = new Thread(r);.... class MyRunnable implements Runnable { public

Dettagli

Processi e multitasking

Processi e multitasking Processi e multitasking Multitasking: caratteristica di un S.O. che permette l esecuzione simultanea (o pseudosimultanea) di più processi Cooperative Multitasking: gestione affidata ai processi stessi,

Dettagli

Processi e multitasking. Thread e Multithreading

Processi e multitasking. Thread e Multithreading Processi e multitasking Thread e Multithreading Multitasking: caratteristica di un S.O. che permette l esecuzione simultanea (o pseudosimultanea) di più processi Cooperative Multitasking: gestione affidata

Dettagli

Corso di Linguaggi di Programmazione

Corso di Linguaggi di Programmazione Corso di Linguaggi di Programmazione Lezione 20 Alberto Ceselli alberto.ceselli@unimi.it Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 20 Maggio 2010 Unità concorrenti in

Dettagli

Corso sul linguaggio Java

Corso sul linguaggio Java Corso sul linguaggio Java Modulo JAVA9 B3.1 Mutua esclusione 1 Prerequisiti Programmazione concorrente Sezione critica Mutua esclusione lock() e unlock() 2 1 Introduzione Si considerino le seguenti situazioni

Dettagli

I Thread in Java parte 2: Sincronizzazione. Sistemi Operativi T AA

I Thread in Java parte 2: Sincronizzazione. Sistemi Operativi T AA I Thread in Java parte 2: Sincronizzazione Sistemi Operativi T AA 2010-2011 1 Sincronizzazione: wait e notify wait set: coda di thread associata ad ogni oggetto, inizialmente vuota. I thread entrano ed

Dettagli

I Thread in Java! parte 2:! Sincronizzazione!

I Thread in Java! parte 2:! Sincronizzazione! I Thread in Java! parte 2:! Sincronizzazione! 1 Sincronizzazione: wait e notify wait set: coda di thread associata ad ogni oggetto, inizialmente vuota. I thread entrano ed escono dal wait set utilizzando

Dettagli

SISTEMI OPERATIVI. Sincronizzazione in Java (Java object lock e segnali wait-notify-notifyall)

SISTEMI OPERATIVI. Sincronizzazione in Java (Java object lock e segnali wait-notify-notifyall) SISTEMI OPERATIVI (MODULO DI INFORMATICA II) LABORATORIO Sincronizzazione in Java (Java object lock e segnali wait-notify-notifyall) Prof. Luca Gherardi Prof.ssa Patrizia Scandurra (anni precedenti) Università

Dettagli

Thread in Java. Linguaggi. Corso di Laurea in Ingegneria delle Telecomunicazioni A.A

Thread in Java. Linguaggi. Corso di Laurea in Ingegneria delle Telecomunicazioni A.A Linguaggi Corso di Laurea in Ingegneria delle Telecomunicazioni A.A. 2010-2011 Alessandro Longheu http://www.diit.unict.it/users/alongheu alessandro.longheu@diit.unict.it Thread in Java 1 Cos è un thread?

Dettagli

Java Virtual Machine

Java Virtual Machine Java Virtual Machine programmi sorgente: files.java compilatore files.class bytecode linker/loader bytecode bytecode Java API files.class interprete macchina ospite Indipendenza di java dalla macchina

Dettagli

Esercizio Sincronizzazione Thread

Esercizio Sincronizzazione Thread Esercitazione di oratorio 17/10/2007 Esercizio Il laboratorio di Informatica del Polo Marzotto e utilizzato da tre tipi di utenti, studenti, tesisti e professori ed ogni utente deve fare una richiesta

Dettagli

Multithreading in Java. Fondamenti di Sistemi Informativi 2014-2015

Multithreading in Java. Fondamenti di Sistemi Informativi 2014-2015 Multithreading in Java Fondamenti di Sistemi Informativi 2014-2015 Multithreading La programmazione concorrente consente di eseguire più processi o thread nello stesso momento. Nel secondo caso si parla

Dettagli

Thread Java. Processi

Thread Java. Processi Thread Java Giacomo Cabri 31 Ottobre 2003 Seminario di Principi di Sistemi Operativi Giacomo Cabri 1 Processi Nei sistemi concorrenti, il termine processo denota la singola attività eseguita in modo indipendente

Dettagli

THREAD IN JAVA. Thread. Un thread (lightweight process) è un singolo flusso sequenziale di controllo all interno di un processo

THREAD IN JAVA. Thread. Un thread (lightweight process) è un singolo flusso sequenziale di controllo all interno di un processo THREAD IN JAVA Come si può realizzare il concetto di Thread in Java? NEL MODO PIU NATURALE! Sono oggetti particolari ai quali si richiede un servizio (chiamato start()) corrispondente al lancio di una

Dettagli

Java threads (2) Programmazione Concorrente

Java threads (2) Programmazione Concorrente Java threads (2) emanuele lattanzi isti information science and technology institute 1/28 Programmazione Concorrente Utilizzo corretto dei thread in Java emanuele lattanzi isti information science and

Dettagli

Introduzione. Java. Threads. Threads. G. Prencipe

Introduzione. Java. Threads. Threads. G. Prencipe Java concorrenza G. Prencipe prencipe@di.unipi.it Introduzione Un processo è un programma in esecuzione con un proprio spazio di indirizzi Un Sistema Operativo multitasking è in grado di eseguire diversi

Dettagli

Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002. Sistemi Operativi Corsi A e B.

Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002. Sistemi Operativi Corsi A e B. Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002 Sistemi Operativi Corsi A e B Esercitazione 15 Il problema dello Sleeping Barber E dato un salone di barbiere,

Dettagli

Thread in Java. Thread = flusso di esecuzione indipendente nel codice del programma

Thread in Java. Thread = flusso di esecuzione indipendente nel codice del programma Thread in Java Thread = flusso di esecuzione indipendente nel codice del programma Come si può realizzare il concetto di Thread in Java? Seguendo la filosofia OO: sono oggetti particolari ai quali si richiede

Dettagli

Architettura degli elaboratori 2 - T. Vardanega 1

Architettura degli elaboratori 2 - T. Vardanega 1 " % &'( &( È ) Architettura degli elaboratori - T. Vardanega Pagina Architettura degli elaboratori - T. Vardanega Pagina define N / posizioni del contenitore / typedef int semaforo; / P decrementa, V incrementa,

Dettagli

Java thread, concorrenza

Java thread, concorrenza Java thread, concorrenza laboratorio 1 A.Memo febbraio 2004 il thread principale in Java ogni programma in esecuzione è un thread il metodo main() è associato al main thread per poter accedere alle proprietà

Dettagli

Multithreading. Multithreading/2

Multithreading. Multithreading/2 Multithreading Osservazioni su EchoServer Programmazione TCP in Java EchoServer ed EchoClient Uso del multithreading nella programmazione di rete ChatClient e ChatServer Esempio di Web server(?) Multithreading/2

Dettagli

Multithreading/2. Più richieste servite simultaneamente > 1 thread per ogni connessione client (+ 1 thread per accettare nuove richieste).

Multithreading/2. Più richieste servite simultaneamente > 1 thread per ogni connessione client (+ 1 thread per accettare nuove richieste). Multithreading Osservazioni su EchoServer Programmazione TCP in Java EchoServer ed EchoClient Uso del multithreading nella programmazione di rete ChatClient e ChatServer Multithreading/2 Più richieste

Dettagli

I Thread in Java! parte 1!

I Thread in Java! parte 1! I Thread in Java! parte 1! 1 Thread Un thread è un singolo flusso sequenziale di controllo all interno di un processo(task) Un thread (o processo leggero) è un unità di esecuzione che condivide codice

Dettagli

Analisi, progettazione e programmazione concorrente

Analisi, progettazione e programmazione concorrente Analisi, progettazione e programmazione concorrente t4 t1 t2 t3 t5 t6 t7 novembre 2015 - versione 5.3 Renato Conte programmazione concorrente - 1/80 - esempi con Java con C++ 11 e con C++ ambiente QT Renato

Dettagli

Programmazione concorrente in Java

Programmazione concorrente in Java Programmazione concorrente in Java Seminario di Principi di Sistemi Operativi - LM Ph.D. Ing. Mariachiara Puviani - mariachiara.puviani@unimore.it http://mars.ing.unimo.it/wiki/index.php/user:mariachiara

Dettagli

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori A.A. 2009/2010

Corso di Laurea in Ingegneria Informatica. Corso di Reti di Calcolatori A.A. 2009/2010 Corso di Laurea in Ingegneria Informatica Corso di Reti di Calcolatori l Introduzione ai Thread in Java A.A. 2009/2010 1 Thread Un thread è un flusso sequenziale di esecuzione di istruzioni all interno

Dettagli

Programmazione Concorrente e Distribuita

Programmazione Concorrente e Distribuita Programmazione Concorrente e Distribuita Esame scritto del 22 Marzo 2012 Versione K Esercizio 1 (5 punti) Si consideri il codice seguente. 1 public c l a s s Redwood extends Tree { 2 public s t a t i c

Dettagli

Esercitazione 15. Il problema dello Sleeping Barber

Esercitazione 15. Il problema dello Sleeping Barber Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002 Sistemi Operativi Corsi A e B Esercitazione 15 Il problema dello Sleeping Barber E dato un salone di barbiere,

Dettagli

GESTIONE DEI PROCESSI

GESTIONE DEI PROCESSI Sistemi Operativi GESTIONE DEI PROCESSI Processi Concetto di Processo Scheduling di Processi Operazioni su Processi Processi Cooperanti Concetto di Thread Modelli Multithread I thread in Java Concetto

Dettagli

Esercitazioni 7 e 8. Bounded Buffer con sincronizzazione Java (1)

Esercitazioni 7 e 8. Bounded Buffer con sincronizzazione Java (1) Università degli Studi della Calabria Corso di Laurea in Ingegneria Informatica A.A. 2001/2002 Corsi A e B Esercitazioni 7 e 8 Bounded Buffer con sincronizzazione Java (1) public class BoundedBuffer private

Dettagli

Corso di Reti di Calcolatori L-A

Corso di Reti di Calcolatori L-A Università degli Studi di Bologna Facoltà di Ingegneria Corso di Reti di Calcolatori L-A Esercitazione 0 (svolta) Multithreading in Java Luca Foschini Anno accademico 2009/2010 Esercitazione 0 1 Modello

Dettagli

Lezione n.6 LPR A - INFORMATICA THREADS:, SINCRONIZZAZIONE ESPLICITA

Lezione n.6 LPR A - INFORMATICA THREADS:, SINCRONIZZAZIONE ESPLICITA Università degli Studi di Pisa Lezione n.6 LPR A - INFORMATICA THREADS:, SINCRONIZZAZIONE ESPLICITA 27/10/2008 1 THREADS COOPERANTI: IL MONITOR L'interazione esplicita tra threads avviene in un linguaggio

Dettagli

Programmazione concorrente in Java

Programmazione concorrente in Java Programmazione concorrente in Java Multithreading in Java Ogni thread e un oggetto, creato come istanza della classe java.lang.thread La classe Thread contiene tutti i metodi per gestire i threads L utente

Dettagli

Programmazione Concorrente e Distribuita

Programmazione Concorrente e Distribuita Programmazione Concorrente e Distribuita Esame scritto del 19 Dicembre 2011 Versione A Esercizio 1 (5 punti) 1 class A{ 2 S t r i n g s ; 3 4 A( S t r i n g s ){ 5 this. s = s ; 6 System. out. p r i n

Dettagli

Generalita' sui Thread

Generalita' sui Thread Generalita' sui Thread Un thread (o processo leggero) è una attività, descritta da una sequenza di istruzioni, che esegue indipendentemente da altre, all'interno del contesto di esecuzione di un programma.

Dettagli

Diagrammi di attività. Diagrammi di attività. Activity diagrams. Sintassi dei diagrammi di Attività (1) Sintassi dei diagrammi di Attività (2)

Diagrammi di attività. Diagrammi di attività. Activity diagrams. Sintassi dei diagrammi di Attività (1) Sintassi dei diagrammi di Attività (2) Diagrammi di attività,6 PRG % &RUVR GL,QJHJQHULD GHO 6RIWZDUH Diagrammi di attività Activity diagrams I diagrammi di attività, in UML, sono usati per descrivere il comportamento dinamico di un sistema

Dettagli

Programmazione Concorrente e Distribuita

Programmazione Concorrente e Distribuita Programmazione Concorrente e Distribuita Esame scritto del 10 Gennaio 2012 Versione C Esercizio 1 (5 punti) 1 public class Tenor extends S i n g e r { 2 public s t a t i c S t r i n g s i n g ( ) { 3 return

Dettagli

Anno Scolastico 2018/2019 SETTE ANTONIO LOSITO ANTONIO TECNOLOGIE E PROGETTAZIONE DI SISTEMI INFORMATICI E DI TEL.

Anno Scolastico 2018/2019 SETTE ANTONIO LOSITO ANTONIO TECNOLOGIE E PROGETTAZIONE DI SISTEMI INFORMATICI E DI TEL. Anno Scolastico 2018/2019 PROGRAMMA DIDATTICO CONSUNTIVO CLASSE 4EI Docenti SETTE ANTONIO LOSITO ANTONIO Disciplina TECNOLOGIE E PROGETTAZIONE DI SISTEMI INFORMATICI E DI TEL. Unità di lavoro 1: Moduli

Dettagli

THREAD. Programmazione in rete e laboratorio. Come si crea un thread

THREAD. Programmazione in rete e laboratorio. Come si crea un thread Programmazione in rete e laboratorio JAVA - Thread Alberto Martelli THREAD Thread: flusso sequenziale di controllo (esecuzione di istruzioni) in un programma. Nello stesso programma si possono far partire

Dettagli

Corso di Linguaggi di Programmazione

Corso di Linguaggi di Programmazione Corso di Linguaggi di Programmazione Lezione 12 Alberto Ceselli ceselli@dti.unimi.it Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 21 Aprile 2007 Concorrenza a livello di

Dettagli

Java: costrutti avanzati

Java: costrutti avanzati Java: costrutti avanzati Costrutti relativi alla versione 1.1 Variabili final Classi interne Gestione delle eccezioni Programmazione concorrente 109 Variabili final A partire dalla versione 1.1 del linguaggio,

Dettagli

Definizione di thread Proprietà dei thread in Java Gestione delle priorità nei programmi multithreaded Gruppi di thread Accesso a variabili condivise

Definizione di thread Proprietà dei thread in Java Gestione delle priorità nei programmi multithreaded Gruppi di thread Accesso a variabili condivise CEFRIEL Centro per la Formazione e la Ricerca in Ingegneria dell Informazione Politecnico di Milano Java Multithreading Programmazione concorrente in Java Docente: Diego Peroni peroni@cefriel.it Indice

Dettagli

Processi e Thread. Walter Cazzola Dipartimento di Informatica e Comunicazione Università à degli Studi di Milano.

Processi e Thread. Walter Cazzola Dipartimento di Informatica e Comunicazione Università à degli Studi di Milano. Processi e Thread Processi e Thread: Il Caso Java. Walter Cazzola Dipartimento di Informatica e Comunicazione Università à degli Studi di Milano. e-mail: cazzola@disi.unige.it Walter Cazzola Processi e

Dettagli

Esercizi sui Thread. Esercitazione di Laboratorio di Programmazione di Rete A. Daniele Sgandurra 24/09/2008. Università di Pisa

Esercizi sui Thread. Esercitazione di Laboratorio di Programmazione di Rete A. Daniele Sgandurra 24/09/2008. Università di Pisa Esercizi sui Thread Esercitazione di Laboratorio di Programmazione di Rete A Daniele Sgandurra Università di Pisa 24/09/2008 Creare Thread: l Interfaccia Runnable Per eseguire un attività in un thread

Dettagli

SISTEMI OPERATIVI. Java multithreading. Prof. Luca Gherardi Prof.ssa Patrizia Scandurra (anni precedenti) (MODULO DI INFORMATICA II) LABORATORIO

SISTEMI OPERATIVI. Java multithreading. Prof. Luca Gherardi Prof.ssa Patrizia Scandurra (anni precedenti) (MODULO DI INFORMATICA II) LABORATORIO SISTEMI OPERATIVI (MODULO DI INFORMATICA II) LABORATORIO Java multithreading Prof. Luca Gherardi Prof.ssa Patrizia Scandurra (anni precedenti) Università degli Studi di Bergamo a.a. 2012-13 Sommario Programmazione

Dettagli

Eccezioni e Thread (cenni)

Eccezioni e Thread (cenni) Eccezioni e Thread (cenni) Linguaggi di Programmazione: Paradigmi di Programmazione (Sperimentazioni) Matteo Baldoni Dipartimento di Informatica Universita` degli Studi di Torino C.so Svizzera, 185 I-10149

Dettagli

Multithreading in Java I parte. Lorenzo Gallucci

Multithreading in Java I parte. Lorenzo Gallucci Multithreading in Java I parte Lorenzo Gallucci Java: un linguaggio ed un sistema predisposti per il multitasking È possibile creare e gestire Thread nativamente (senza dover ricorrere a librerie esterne)

Dettagli

Programmazione Concorrente e Distribuita

Programmazione Concorrente e Distribuita Programmazione Concorrente e Distribuita Esame scritto del 29 Giugno 2012 Versione I Esercizio 1 ( punti) 1 class Mammal { 2 S t r i n g name = f u r r y ; 3 S t r i n g makenoise ( ) { return g e n e

Dettagli

Soluzioni ai problemi di Mutua Esclusione Primitive di sincronizzazione. Soluzioni ai problemi di Mutua EsclusionePrimitive di sincronizzazione

Soluzioni ai problemi di Mutua Esclusione Primitive di sincronizzazione. Soluzioni ai problemi di Mutua EsclusionePrimitive di sincronizzazione Soluzioni ai problemi di Mutua Esclusione Primitive di sincronizzazione Soluzioni basate su primitive di sincronizzazione Le primitive di sincronizzazione piú comuni sono: Lock (mutex) - realizzati in

Dettagli

Programmazione Concorrente e Distribuita

Programmazione Concorrente e Distribuita Programmazione Concorrente e Distribuita Esame scritto del 27 Agosto 2012 Versione AA Esercizio 1 (5 punti) 1 class A{ 2 S t r i n g s ; 3 4 A( S t r i n g s ){ 5 this. s = s ; 6 System. out. p r i n t

Dettagli

Multithreading in Java IS-8 1

Multithreading in Java IS-8 1 Multithreading in Java IS-8 1 Flusso (thread) di esecuzione In un programma sequenziale esiste un solo flusso di esecuzione attivo In un programma concorrente esistono più flussi di esecuzione attivi (task)

Dettagli

Corso di Linguaggi di Programmazione

Corso di Linguaggi di Programmazione Corso di Linguaggi di Programmazione Lezione 20 Alberto Ceselli alberto.ceselli@unimi.it Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 14 Maggio 2013 Programmazione concorrente:

Dettagli

Gestione dei thread in Java LSO 2008

Gestione dei thread in Java LSO 2008 Gestione dei thread in Java LSO 2008 Cos è un Thread? Si può avere la necessità di suddividere un programma in sottoattività separate da eseguire indipendentemente l una dall altra Queste sottoattività

Dettagli

Laboratorio Reti di Calcolatori Laurea Triennale in Comunicazione Digitale. Anno Accademico 2012/2013

Laboratorio Reti di Calcolatori Laurea Triennale in Comunicazione Digitale. Anno Accademico 2012/2013 Laboratorio Reti di Calcolatori Laurea Triennale in Comunicazione Digitale Anno Accademico 2012/2013 Thread e processi Da software ci si attende la concorrenza. Java è stato progettato per supportare concorrenza

Dettagli

Sincronizzazione con Java

Sincronizzazione con Java Sincronizzazione con Java Corse critiche e sincronizzazione Java implementa un meccanismo simile al monitor per garantire la sincronizzazione fra thread Ogni oggetto ha un lock associato ad esso Nelle

Dettagli

Programmazione Concorrente

Programmazione Concorrente Programmazione Concorrente Programmazione in Ambienti Distribuiti A.A. 2003-04 Programmi sequenziali Stack (Variabili locali) Stack pointer Istruzioni Heap (Oggetti) 2 1 Processi paralleli Processo 1 Processo

Dettagli

JAVA Gestione delle eccezioni e Programmazione concorrente

JAVA Gestione delle eccezioni e Programmazione concorrente JAVA Gestione delle eccezioni e Programmazione concorrente Andrea BEI (andrea.bei@libero.it) Gestione delle eccezioni Un eccezione è un evento generato in un applicazione in circostanze eccezionali (es:

Dettagli

Thread. Java Thread. 1) come sottoclasse della classe Thread

Thread. Java Thread. 1) come sottoclasse della classe Thread Thread Java Thread Un thread (lightweight process) è un singolo flusso sequenziale di controllo all interno di un processo Due modalità per implementare thread in Java: 1. come sottoclasse della classe

Dettagli

Corso di Programmazione Concorrente. Java Thread. Valter Crescenzi http://crescenzi.dia.uniroma3.it

Corso di Programmazione Concorrente. Java Thread. Valter Crescenzi http://crescenzi.dia.uniroma3.it Corso di Programmazione Concorrente Java Thread Valter Crescenzi http://crescenzi.dia.uniroma3.it Sommario Java Thread e supporto alla PC della piattaforma Java Creazione di Thread con java.lang.thread

Dettagli

Corso sul linguaggio Java

Corso sul linguaggio Java Corso sul linguaggio Java Modulo JAVA9 B2 Multithreading 1 Prerequisiti Programmazione base in Java Significato di multithreading Concetti di base sui sistemi operativi Attesa attiva Attesa passiva 2 1

Dettagli

: $. $ # % 9 ; / % <! = > ;!! " # $ % &! 8 - & $ 9 9 -! %!! " # $ % &!

: $. $ # % 9 ; / % <! = > ;!!  # $ % &! 8 - & $ 9 9 -! %!!  # $ % &! : $. $ # % 9 ; / % ;!! " # $ % &! Un thread (o processo leggero) è una attività, descritta da una sequenza di istruzioni, che esegue all'interno del contesto di esecuzione di un programma. Un thread

Dettagli

Nona Esercitazione. Thread e memoria condivisa Sincronizzazione tramite semafori

Nona Esercitazione. Thread e memoria condivisa Sincronizzazione tramite semafori Nona Esercitazione Thread e memoria condivisa Sincronizzazione tramite semafori Agenda Esercizio 1 DA SVOLGERE Sincronizzazione avanzata produttore consumatore tramite semafori Esercizio 2 DA SVOLGERE

Dettagli

Sincronizzazione con Java

Sincronizzazione con Java Sincronizzazione con Java Corse critiche e sincronizzazione Java implementa un meccanismo simile al monitor per garantire la sincronizzazione fra thread Ogni oggetto ha un lock associato ad esso Nelle

Dettagli

Introduzione: i thread. Laboratorio di programmazione di rete Java Thread! Esempio di thread C (dato per scontato)

Introduzione: i thread. Laboratorio di programmazione di rete Java Thread! Esempio di thread C (dato per scontato) Introduzione: i thread Laboratorio di programmazione di rete Java Thread! Corso B Anno accademico 2007-2008 Prof. Marco Danelutto Assistente Dr.ssa Sonia Campa Concetto di thread (richiami di laboratorio

Dettagli

Comunicazione e sincronizzazione tra processi Indice. Comunicazione e sincronizzazione. Esempio 1. Monitor - 1. Monitor - 2. Monitor - 3.

Comunicazione e sincronizzazione tra processi Indice. Comunicazione e sincronizzazione. Esempio 1. Monitor - 1. Monitor - 2. Monitor - 3. tra processi tra processi Indice Meccanismi. Monitor. Scambio di messaggi.3 Barriere Problemi classici 3 Stallo Monitor - La soluzione mediante semafori è di uso difficile e rischioso Un posizionamento

Dettagli

I thread di uno stesso processo condividono dati e codice del processo, ma lo stack di esecuzione ed il program counter sono privati.

I thread di uno stesso processo condividono dati e codice del processo, ma lo stack di esecuzione ed il program counter sono privati. Un thread (o processo leggero) è una attività, descritta da una sequenza di istruzioni, che esegue all'interno del contesto di esecuzione di un programma. Un thread procede nella sua esecuzione per portare

Dettagli

Bibliografia. Studio di caso: Bancomat Automated Teller Machine. uso dei diagrammi: use case, classi, collaborazione, stato

Bibliografia. Studio di caso: Bancomat Automated Teller Machine. uso dei diagrammi: use case, classi, collaborazione, stato ,6 PRG % &RUVR GL,QJHJQHULD GHO 6RIWZDUH 80/ Bibliografia Studio di caso: Bancomat Automated Teller Machine uso dei diagrammi: use case, classi, collaborazione, stato - Hassan Gomaa: Designing concurrent

Dettagli

Capitolo 4: Processi

Capitolo 4: Processi Capitolo 4: Processi Concetto di processo Scheduling dei processi Operazioni sui processi Processi cooperanti Comunicazione tra processi Comunicazione nei sistemi client-server 4.1 Concetto di processo

Dettagli

T 1. Per un processo con più thread di controllo, lo stato di avanzamento della computazione di ogni thread è dato da:

T 1. Per un processo con più thread di controllo, lo stato di avanzamento della computazione di ogni thread è dato da: Un thread (o processo leggero) è una attività, descritta da una sequenza di istruzioni, che esegue all'interno del contesto di esecuzione di un programma. Un thread procede nella sua esecuzione per portare

Dettagli

Corso di Programmazione Concorrente. Java Thread. Valter Crescenzi

Corso di Programmazione Concorrente. Java Thread. Valter Crescenzi Corso di Programmazione Concorrente Java Thread Valter Crescenzi http://crescenzi.inf.uniroma3.it Sommario Java Thread e supporto alla PC della piattaforma Java Creazione di Thread con java.lang.thread

Dettagli

Threads in Java. I threads. Costruttori. Prof.ssa Sara Michelangeli

Threads in Java. I threads. Costruttori. Prof.ssa Sara Michelangeli Threads in Java Prof.ssa Sara Michelangeli I threads I threads o "processi leggeri" (light weight process) sono flussi di esecuzione nell'ambito di uno stesso processo, che condividono tra loro risorse

Dettagli

Corso di Linguaggi di Programmazione

Corso di Linguaggi di Programmazione Corso di Linguaggi di Programmazione Lezione 18 Alberto Ceselli alberto.ceselli@unimi.it Dipartimento di Tecnologie dell Informazione Università degli Studi di Milano 19 Maggio 2009 Supporto alla programmazione

Dettagli

Lab 2: Sincronizzazione diretta/indiretta in Java

Lab 2: Sincronizzazione diretta/indiretta in Java Dept. of Computer Science Lab 2: Sincronizzazione diretta/indiretta in Java Matteo Camilli matteo.camilli@unimi.it Laboratorio di Sistemi Operativi a.a. 2015/16 Università degli Studi di Bergamo 1 Esercizi

Dettagli

Threads. Processi Single e Multi-thread

Threads. Processi Single e Multi-thread Threads Processi Single e Multi-thread 1 Benefici Diminuisce i tempi di risposta di una applicazione: durante attesa altre attività della applicazione possono essere fatte Condivisione delle risorse: tutti

Dettagli

INTRODUZIONE AL MECCANISMO DEI THREAD DI JAVA

INTRODUZIONE AL MECCANISMO DEI THREAD DI JAVA INTRODUZIONE AL MECCANISMO DEI THREAD DI JAVA Java mette a disposizione la classe Thread e l interfaccia Runnable per consentire l'implementazione di tipi thread definiti dall'utente. In entrambi i casi,

Dettagli

Esercizio sul Monitor in Java. 18 maggio 2011

Esercizio sul Monitor in Java. 18 maggio 2011 Esercizio sul Monitor in Java 18 maggio 2011 1 Il Bar dello Stadio In uno stadio e` presente un unico bar a disposizione di tutti i tifosi che assistono alle partite di calcio. I tifosi sono suddivisi

Dettagli

Nona Esercitazione. Thread e memoria condivisa Sincronizzazione tramite semafori

Nona Esercitazione. Thread e memoria condivisa Sincronizzazione tramite semafori Nona Esercitazione Thread e memoria condivisa Sincronizzazione tramite semafori Agenda Esercizio 1 DA SVOLGERE Sincronizzazione avanzata produttore consumatore tramite semafori Esercizio 2 DA SVOLGERE

Dettagli

PROVA FINALE Ingegneria del software

PROVA FINALE Ingegneria del software PROVA FINALE Ingegneria del software Ing. Jody Marca jody.marca@polimi.it Laboratorio N 6 Cosa faremo oggi 2 Comunicazione RMI Comunicazione RMI Multi-Thread Remote Method Invocation 3 L obiettivo è di

Dettagli

Verifica e Validazione del Software

Verifica e Validazione del Software Verifica e Validazione del Software Testing Object Oriented Ingegneria del Software 2 Testing Object Oriented 1 Riferimenti Ian Sommerville, Ingegneria del Software, capitoli 22-23-24 (più dettagliato

Dettagli