I thread nel sistema operativo LINUX: Linuxthreads
|
|
|
- Eugenia Valle
- 10 anni fa
- Просмотров:
Транскрипт
1 I thread nel sistema operativo LINUX: Linuxthreads LinuxThreads: Caratteristiche Processi leggeri realizzati a livello kernel System call clone: int clone(int (*fn) (void *arg), void *child_stack, int flags, void *arg) E` specifica di Linux: scarsa portabilita`! Libreria LinuxThreads: funzioni di gestione dei threads, in conformita` con lo standard POSIX c (pthreads): Creazione/terminazione threads Sincronizzazione threads:lock, [semafori], variabili condizione Etc. Portabilita` Sistemi Operativi L-A 2 1
2 LinuxThreads Caratteristiche threads: Il thread e` realizzato a livello kernel (e` l unita` di schedulazione) I thread vengono creati all interno di un processo (task) per eseguire una funzione Ogni thread ha il suo PID (a differenza di POSIX: distinzione tra task e threads) Gestione dei segnali non conforme a POSIX: Non c e` la possibilita` di inviare un segnale a un task. SIGUSR1 e SIGUSR2 vengono usati per l implementazione dei threads e quindi non sono piu` disponibili. Sincronizzazione: Lock: mutua esclusione (pthread_mutex_lock/unlock) Semafori: esterni alla libreria pthread <semaphore.h> (POSIX b) Variabili condizione : (pthread_cond_wait,pthread_cond_signal) Sistemi Operativi L-A 3 Rappresentazione dei threads Il thread e` l unita` di scheduling, ed e` univocamente individuato da un indentificatore (intero): pthread_t tid; Il tipo pthread_t e`dichiarato nell header file: <pthread.h> Sistemi Operativi L-A 4 2
3 Creazione di thread: pthread_create Creazione di thread: #include <pthread.h> int pthread_create(pthread_t *thread,pthread_attr_t *attr, void *(*start_routine)(void *), void * arg); Dove: thread: e` il puntatore alla variabile che raccogliera` il thread_id (PID) start_routine: e` il puntatore alla funzione che contiene il codice del nuovo thread arg: e` il puntatore all eventuale vettore contenente i parametri della funzione da eseguire attr: puo` essere usato per specificare eventuali attributi da associare al thread (di solito: NULL): ad esempio parametri di scheduling: priorita` etc.(solo per superuser!) Legame con gli altri threads (ad esempio: detached o no) Ritorna : 0 in caso di successo, altrimenti un codice di errore (!=0) Sistemi Operativi L-A 5 LinuxThreads: creazione di threads Ad esempio: int A, B; /* variabili comuni ai thread che verranno creati*/ void * codice(void *){ /*definizione del codice del thread */ main() {pthread_t t1, t2;.. pthread_create(&t1,null, codice, NULL); pthread_create(&t2,null, codice, NULL);.. Vengono creati due thread (di tid t1 e t2) che eseguono le istruzioni contenute nella funzione codice: I due thread appartengono allo stesso task (processo) e condividono le variabili globali del programma che li ha generati (ad esempio A e B). Sistemi Operativi L-A 6 3
4 Terminazione di thread: pthread_exit Terminazione di thread: void pthread_exit(void *retval); Dove: retval: e` il puntatore alla variabile che contiene il valore di ritorno (puo` essere raccolto da altri threads, v. pthread_join). E` una chiamata senza ritorno. Alternativa: return(); Sistemi Operativi L-A 7 pthread_join Un thread puo` sospendersi in attesa della terminazione di un altro thread con: int pthread_join(pthread_t th, void **thread_return); Dove: th: e` il pid del particolare thread da attendere thread_return: e` il puntatore alla variabile dove verra` memorizzato il valore di ritorno del thread (v. pthread_exit) Sistemi Operativi L-A 8 4
5 Esempio: creazione di thread /*Linuxthreads: esempio 1.c */ #include <stdio.h> #include <stdlib.h> #include <pthread.h> void *my_thread_process (void * arg) { int i; for (i = 0 ; i < 5 ; i++) { printf ("Thread %s: %d\n", (char*)arg, i); sleep (1); pthread_exit (0); Sistemi Operativi L-A 9 main () { pthread_t th1, th2; int retcode; if (pthread_create(&th1,null,my_thread_process,"1") < 0) { fprintf (stderr, "pthread_create error for thread 1\n"); if (pthread_create(&th2,null,my_thread_process,"2") < 0) { fprintf (stderr, "pthread_create error for thread 2\n"); retcode = pthread_join (th1, NULL); if (retcode!= 0) fprintf (stderr, "join fallito %d\n", retcode); else printf( terminato il thread 1\n); retcode = pthread_join (th2, NULL); if (retcode!= 0) fprintf (stderr, "join fallito %d\n", retcode); else printf( terminato il thread 2\n); return 0; Sistemi Operativi L-A 10 5
6 Compilazione Per compilare un programma che usa i linuxthreads: gcc -D_REENTRANT -o prog prog.c lpthread [aciampolini@ccib48 threads]$ prog Thread 1: 0 Thread 2: 0 Thread 1: 1 Thread 2: 1 Thread 1: 2 Thread 2: 2 Thread 1: 3 Thread 2: 3 Thread 1: 4 Thread 2: 4 terminato il thread 1 terminato il thread 2 [aciampolini@ccib48 threads]$ Sistemi Operativi L-A 11 Sincronizzazione: MUTEX Lo standard POSIX c (libreria <pthread.h>) definisce i semafori binari (o lock, mutex, etc.) sono semafori il cui valore puo` essere 0 oppure 1 (occupato o libero); vengono utilizzati tipicamente per risolvere problemi di mutua esclusione operazioni fondamentali: inizializzazione: pthread_mutex_init locking: pthread_mutex_lock unlocking: pthread_mutex_unlock Per operare sui mutex: pthread_mutex_t : tipo di dato associato al mutex; esempio: pthread_mutex_t mux; Sistemi Operativi L-A 12 6
7 MUTEX: inizializzazione L'inizializzazione di un mutex si puo`realizzare con: int pthread_mutex_init(pthread_mutex_t* mutex, const pthread_mutexattr_t* attr) attribuisce un valore iniziale all'intero associato al semaforo (default: libero): mutex : individua il mutex da inizializzare attr : punta a una struttura che contiene gli attributi del mutex; se NULL, il mutex viene inizializzato a libero (default). in alternativa, si puo` inizializzare il mutex a default con la macro: PTHREAD_MUTEX_INIZIALIZER esempio: pthread_mutex_t mux= PTHREAD_MUTEX_INIZIALIZER ; Sistemi Operativi L-A 13 MUTEX: lock/unlock Locking/unlocking si realizzano con: int pthread_mutex_lock(pthread_mutex_t* mux); int pthread_mutex_unlock(pthread_mutex_t* mux); lock: se il mutex mux e` occupato,il thread chiamante si sospende; altrimenti occupa il mutex. unlock: se vi sono processi in attesa del mutex, ne risveglia uno; altrimenti libera il mutex. Sistemi Operativi L-A 14 7
8 Esempio mutex /*Linuxthreads: esempio2.c uso dei mutex */ #include <stdio.h> #include <stdlib.h> #include <pthread.h> #define MAX 10 pthread_mutex_t M; /* def.mutex condiviso */ int DATA=0; /* variabile condivisa */ int accessi1=0; /*num. di accessi thread 1 */ int accessi2=0; /*num. di accessi thread 2 */ void *thread1_process (void * arg) { int k=1; while(k) { pthread_mutex_lock(&m); /*prologo */ accessi1++; DATA++; k=(data>=max?0:1); printf("accessi di T1: %d\n", accessi1); pthread_mutex_unlock(&m); /*epilogo */ pthread_exit (0); Sistemi Operativi L-A 15 void *thread2_process (void * arg) { int k=1; while(k) { pthread_mutex_lock(&m); /*prologo sez. critica */ accessi2++; DATA++; k=(data>=max?0:1); printf("accessi di T2: %d\n", accessi2); pthread_mutex_unlock(&m); /*epilogo sez. critica*/ pthread_exit (0); Sistemi Operativi L-A 16 8
9 main(){ pthread_t th1, th2; /* il mutex e` inizialmente libero: */ pthread_mutex_init (&M, NULL); if (pthread_create(&th1, NULL, thread1_process, NULL) < 0) { fprintf (stderr, "create error for thread 1\n"); if (pthread_create(&th2, NULL,thread2_process,NULL) < 0) { fprintf (stderr, "create error for thread 2\n"); pthread_join (th1, NULL); pthread_join (th2, NULL); Sistemi Operativi L-A 17 Test $ $ gcc -D_REENTRANT -o tlock lock.c -lpthread $./tlock accessi di T2: 1 accessi di T1: 1 accessi di T2: 2 accessi di T1: 2 accessi di T1: 3 accessi di T1: 4 accessi di T1: 5 accessi di T1: 6 accessi di T1: 7 accessi di T1: 8 accessi di T2: 3 $ Sistemi Operativi L-A 18 9
10 LinuxThreads: Semafori Memoria condivisa: uso dei semafori (POSIX b) Semafori: libreria <semaphore.h> sem_init: inizializzazione di un semaforo sem_wait: p sem_post: v sem_t : tipo di dato associato al semaforo; esempio: static sem_t my_sem; Sistemi Operativi L-A 19 Operazioni sui semafori Inizializzazione di un semaforo: int sem_init(sem_t *sem, int pshared, unsigned int value); attribuisce un valore iniziale all'intero associato al semaforo: sem: individua il semaforo da inizializzare pshared : 0, se il semaforo non e` condiviso tra task, oppure non zero (sempre zero). value : e` il valore iniziale da assegnare al semaforo. sem_t : tipo di dato associato al semaforo; esempio: ritorna sempre 0. static sem_t my_sem; Sistemi Operativi L-A 20 10
11 Operazioni sui semafori: sem_wait Operazione p: int sem_wait(sem_t *sem); dove: sem: individua il semaforo sul quale operare. e` la p di Dijkstra: se il valore del semaforo e` uguale a zero, sospende il thread chiamante nella coda associata al semaforo; altrimenti ne decrementa il valore. Sistemi Operativi L-A 21 Operazione v : Operazioni sui semafori: sem_post int sem_post(sem_t *sem); dove: sem: individua il semaforo sul quale operare. e` la v di Dijkstra: se c'e` almeno un thread sospeso nella coda associata al semaforo sem, viene risvegliato; altrimenti il valore del semaforo viene incrementato. Sistemi Operativi L-A 22 11
12 Semafori: esempio /* esempio3.c - tre processi che competono per incrementare: la variabile V */ #include <stdio.h> #include <stdlib.h> #include <pthread.h> #include <semaphore.h> #define MAX 13 static sem_t m; /* semaforo per la mutua esclusione nell'accesso alla sezione critica */ int V=0,F=0; Sistemi Operativi L-A 23 void *thread1_process (void * arg) { int k=1; while(k) { sem_wait(&m); printf("thread1: dentro la sezione critica (V=%d)\n",V); if (V<MAX) V++; else { k=0; printf("t1: %d (V=%d)\n",++F, V); sem_post(&m); sleep(1); pthread_exit (0); Sistemi Operativi L-A 24 12
13 void *thread2_process (void * arg) { int k=1; while(k) { sem_wait(&m); printf("thread2: dentro la sezione critica (V=%d)\n",V); if (V<MAX) V++; else { k=0; printf("t2: %d (V=%d)\n",++F, V); sem_post(&m); sleep(1); /* per rallentare...*/ pthread_exit (0); Sistemi Operativi L-A 25 void *thread3_process (void * arg) { int k=1; while(k) { sem_wait(&m); printf("thread3: dentro la sezione critica (V=%d)\n",V); if (V<MAX) V++; else { k=0; printf("t3: %d (V=%d)\n",++F, V); sem_post(&m); sleep(1); /* per rallentare...*/ pthread_exit (0); Sistemi Operativi L-A 26 13
14 main () { pthread_t th1, th2,th3; sem_init (&m, 0, 1); if (pthread_create(&th1, NULL, thread1_process, NULL) < 0) { fprintf (stderr, "pthread_create error for thread 1\n"); if (pthread_create(&th2, NULL,thread2_process,NULL) < 0) { fprintf (stderr, "pthread_create error for thread 2\n"); if (pthread_create(&th3,null,thread3_process, NULL) < 0) { fprintf (stderr, "pthread_create error for thread 3\n"); Sistemi Operativi L-A 27 Esercizi Proposti 14
15 Esercizi proposti Facendo uso degli strumenti di sincronizzazione disponibili nella libreria LinuxThreads, risolvere il problema "produttori&consumatori" nei seguenti casi: 1. comunicazione uno-a-uno con buffer di capacita` 1 2. comunicazione uno-a-uno con buffer di capacita` n Sistemi Operativi L-A 29 Esercizio 1: impostazione Produttore inserimento buffer prelievo Consumatore Sistemi Operativi L-A 30 15
16 #include <stdio.h> #include <stdlib.h> #include <pthread.h> Impostazione (1 e 2) <...variabili globali: buffer, semafori o mutex, etc.> void *thread_produttore(void * arg)/*codice produttore*/ { messaggio M; while(1) { M=produci(); <... sincronizzazione (prologo)...> inserimento(m); <...sincronizzazione (epilogo)...> pthread_exit (0); Sistemi Operativi L-A 31 void *thread_consumatore(void * arg)/*codice consumatore*/ { messaggio M; while(1) { <... sincronizzazione (prologo)...> M=prelievo(..); <...sincronizzazione (epilogo)...> consuma(m); pthread_exit (0); Sistemi Operativi L-A 32 16
17 main () { pthread_t P, C; void *ret; <inizializzazione strumenti di sincronizzazione (semafori e/o mutex)..> if (pthread_create (&th1, NULL, thread.produttore, NULL) < 0) { fprintf (stderr, "pthread_create error for thread 1\n"); if (pthread_create(&th2,null, thread_consumatore, NULL) < 0) {fprintf (stderr, "pthread_create error for thread \n"); pthread_join (th1, &ret); pthread_join (th2, &ret); Sistemi Operativi L-A 33 Osservazioni/suggerimenti Cercare, quando possibile, di usare gli strumenti di sincronizzazione della libreria pthread (mutex). Sistemi Operativi L-A 34 17
Esercitazione 2! Mutex e semafori POSIX. 3 Novembre 2016
Esercitazione 2! Mutex e semafori POSIX 3 Novembre 2016 Strumenti di sincronizzazione nella libreria LinuxThread I semafori nelle librerie pthread e LinuxThreads La libreria pthread definisce soltanto
Thread: sincronizzazione Esercitazioni del 09 Ottobre 2009
Thread: sincronizzazione Esercitazioni del 09 Ottobre 2009 Luca Fossati, Fabrizio Castro, Vittorio Zaccaria October 10, 2009 Sincronizzazione - 1 1 Esercizio 1: Sincronizzazione - 1 Qual è il problema
Monitor pthreads. Esercizio
Monitor pthreads Esercizio Esercizio monitor Una società di noleggio di automobili offre ai propri clienti tre tipi di automobili: piccole, medie, grandi. Ogni tipo di auto è disponibile in numero limitato
Perche le CPU multicore
Perche le CPU multicore I processi industriali producono chip sempre piu densi in termini di transistor 2000 Inoltre: Watt ~ Volt 2 x frequenza Frequenza ~ Volt Watt ~ frequenza 3 Il rapporto Watt/mm 2
Corso di Laboratorio di Sistemi Operativi
Corso di Laboratorio di Sistemi Operativi Lezione 7 Alessandro Dal Palù email: [email protected] web: www.unipr.it/~dalpalu Threads Un thread è l unità di base per l utilizzo della CPU. Composto
Sistemi Operativi L-A. Esercizi 14 Giugno 2007. Esercizio monitor
Sistemi Operativi L-A Esercizi 14 Giugno 2007 Esercizio monitor Si consideri la toilette di un ristorante. La toilette è unica per uomini e donne. Utilizzando la libreria pthread, si realizzi un'applicazione
Computazione multi-processo. Condivisione, Comunicazione e Sincronizzazione dei Processi. Segnali. Processi e Threads Pt. 2
Computazione multi-processo Avere più processi allo stesso momento implica/richiede Processi e Threads Pt. 2 Concorrenza ed efficienza Indipendenza e protezione dei dati ma deve prevedere/permettere anche:
Sistemi Operativi (M. Cesati)
Sistemi Operativi (M. Cesati) Compito scritto del 16 luglio 2015 Nome: Matricola: Corso di laurea: Cognome: Crediti da conseguire: 5 6 9 Scrivere i dati richiesti in stampatello. Al termine consegnare
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
Creazione di thread. In Linux si utilizzano le librerie pthread (POSIX thread) per lavorare con i thread:
Thread Un thread o lightweight process (LWP) è un unità di utilizzo della CPU che consiste di: un program counter, un insieme di registri, uno stack space. Tale unità condivide con gli altri peer thread
Realizzazione di Politiche di Gestione delle Risorse: i Semafori Privati
Realizzazione di Politiche di Gestione delle Risorse: i Semafori Privati Condizione di sincronizzazione Qualora si voglia realizzare una determinata politica di gestione delle risorse,la decisione se ad
Università di Roma Tor Vergata Corso di Laurea triennale in Informatica Sistemi operativi e reti A.A Pietro Frasca.
Università di Roma Tor Vergata Corso di Laurea triennale in Informatica Sistemi operativi e reti A.A. 2016-17 Pietro Frasca Lezione 20 Giovedì 22-12-2016 Comunicazione: pipe In Unix, processi possono comunicare
2. I THREAD. 2.1 Introduzione
2. I THREAD 2.1 Introduzione Il tipo di parallelismo che è opportuno avere a disposizione nelle applicazioni varia in base al grado di cooperazione necessaria tra le diverse attività svolte in parallelo:
Il costrutto monitor
Il Monitor 1 Monitor Definizione del monitor Esempi d uso Realizzazione del costrutto monitor Realizzazione di politiche di gestione delle risorse Chiamate innestate a procedure del monitor Realizzazione
Thread. La libreria Pthread Stefano Quer Dipartimento di Automatica e Informatica Politecnico di Torino
Thread La libreria Pthread Stefano Quer Dipartimento di Automatica e Informatica Politecnico di Torino 2 Librerie di thread Fornisce l interfaccia per effettuare la gestione dei thread da parte del programmatore
Processi programma processo processo Stati di un processo Attesa di caricamento new Pronto ( ready ) Esecuzione running Waiting ( in Attesa )
Processi Un processo è l insieme delle azioni compiute dal processore per eseguire un programma. Si può semplificare dicendo che "un processo è un programma in esecuzione". Per meglio definire un processo
Sincronizzazione. I semafori Stefano Quer Dipartimento di Automatica e Informatica Politecnico di Torino
Sincronizzazione I semafori Stefano Quer Dipartimento di Automatica e Informatica Politecnico di Torino 2 Introduzione Le soluzioni Software sono complesse da utilizzare dal punto di vista del programmatore
Posix Threads: l evoluzione dei processi UNIX
Posix Threads: l evoluzione dei processi UNIX Raffaele Quitadamo, PhD in Computer Science Università di Modena e Reggio Emilia [email protected] Sommario Pthreads vs Unix processes L API per
Cosa sono i semafori?
Mutex Cosa sono i semafori? I semafori sono primitive fornite dal sistema operativo per permettere la sincronizzazione tra processi e/o thread. Semafori di mutua esclusione con i thread POSIX 2 Operazioni
Il costrutto monitor [Hoare 74]
Il monitor 1 Il costrutto monitor [Hoare 74] Definizione: Costrutto sintattico che associa un insieme di operazioni (entry o public) ad una struttura dati comune a più processi, tale che: Le operazioni
= PTHREAD_MUTEX_INITIALIZER
MUTEX Prof.ssa Sara Michelangeli Quando si programma in modalità concorrente bisogna gestire le problematiche di accesso alle eventuali sezioni critiche. Una sezione critica è una sequenza di istruzioni
Sistemi Operativi. Processi GESTIONE DEI PROCESSI. Concetto di Processo. Scheduling di Processi. Operazioni su Processi. Processi Cooperanti
GESTIONE DEI PROCESSI 4.1 Processi Concetto di Processo Scheduling di Processi Operazioni su Processi Processi Cooperanti Concetto di Thread Modelli Multithread I thread in diversi S.O. 4.2 Concetto di
Lab. di Sistemi Operativi - Esercitazione n 9- -Thread-
Lab. di Sistemi Operativi - Esercitazione n 9- -Thread- 1 Sommario Esercizi su: Comunicazione tra processi: la funzione pipe() Condivisione dati e codice tra due o più processi: concetto di Thread 2 -
Strutture. Strutture e Unioni. Definizione di strutture (2) Definizione di strutture (1)
Strutture Strutture e Unioni DD cap.10 pp.379-391, 405-406 KP cap. 9 pp.361-379 Strutture Collezioni di variabili correlate (aggregati) sotto un unico nome Possono contenere variabili con diversi nomi
Lezione 5. Processi e thread. Sistemi operativi. Marco Cesati System Programming Research Group Università degli Studi di Roma Tor Vergata
Lezione 5 Sistemi operativi 24 marzo 2015 System Programming Research Group Università degli Studi di Roma Tor Vergata SO 15 5.1 Di cosa parliamo in questa lezione? Relazione tra processi e thread, e relative
Sincronizzazione e comunicazione tra processi in Unix. usati per trasferire ad un processo l indicazione che un determinato evento si è verificato.
Processi parte III Sincronizzazione e comunicazione tra processi in Unix Segnali: usati per trasferire ad un processo l indicazione che un determinato evento si è verificato. Pipe: struttura dinamica,
Allocazione dinamica della memoria - riepilogo
Università degli studi di Milano Dipartimento di Scienze dell Informazione Laboratorio di algoritmi e strutture dati Corso di laurea in Informatica In breve Storage duration Allocazione dinamica della
Semafori. Semafori classici con i thread POSIX 2
Semafori classici Semafori I semafori sono primitive, implementate attraverso dei contatori, fornite dal sistema operativo per permettere la sincronizzazione tra processi e/o thread. Per queste primitive
Il costrutto monitor [Hoare 74]
Il monitor 1 Il costrutto monitor [Hoare 74] Definizione: Costrutto sintattico che associa un insieme di operazioni (entry, o public) ad una struttura dati comune a più processi, tale che: Le operazioni
SISTEMI OPERATIVI. Sincronizzazione dei processi. Domande di verifica. Luca Orrù Centro Multimediale Montiferru 30/05/2007
2007 SISTEMI OPERATIVI Sincronizzazione dei processi Domande di verifica Luca Orrù Centro Multimediale Montiferru 30/05/2007 Sincronizzazione dei processi 1. Si descrivano i tipi di interazione tra processi?
Sistemi Operativi. Lez. 13: primitive per la concorrenza monitor e messaggi
Sistemi Operativi Lez. 13: primitive per la concorrenza monitor e messaggi Osservazioni I semafori sono strumenti particolarmente potenti poiché consentono di risolvere ogni problema di sincronizzazione
Esercizio sul Monitor. Ponte con utenti grassi e magri 11 Novembre 2013
Esercizio sul Monitor Ponte con utenti grassi e magri 11 Novembre 2013 1 Ponte con utenti grassi e magri Si consideri un ponte pedonale che collega le due rive di un fiume. Al ponte possono accedere due
Relazione tra thread e processi
I Thread POSIX Relazione tra modello a processi e a thread Creazione di un thread Attesa Distacco Terminazione Ricerca e confronto Inizializzazione dinamica Relazione tra thread e processi Nel modello
Monitor. Introduzione. Struttura di un TDA Monitor
Monitor Domenico Cotroneo Dipartimento di Informatica e Sistemistica Introduzione E stato introdotto per facilitare la programmazione strutturata di problemi in cui è necessario controllare l assegnazione
Tipi primitivi. Ad esempio, il codice seguente dichiara una variabile di tipo intero, le assegna il valore 5 e stampa a schermo il suo contenuto:
Tipi primitivi Il linguaggio Java offre alcuni tipi di dato primitivi Una variabile di tipo primitivo può essere utilizzata direttamente. Non è un riferimento e non ha senso tentare di istanziarla mediante
Il descrittore di processo (PCB)
Il descrittore di processo (PC) Il S.O. gestisce i processi associando a ciascuno di essi un struttura dati di tipo record detta descrittore di processo o Process Control lock (PC) Il PC contiene tutte
La struttura dati ad albero binario
La struttura dati ad albero binario L albero è una struttura dati nella quale le informazioni sono organizzate in modo gerarchico, dall alto verso il basso. Gli elementi di un albero si chiamano nodi,
Sistemi Operativi. Lezione 7 Comunicazione tra processi
Lezione 7 Comunicazione tra processi Introduzione La soluzione sw al problema della mutua esclusione è abbastanza complessa Algoritmo di Peterson La soluzione hw mediante disabilitazione degli interrupt
Esercizio: gestione di un conto corrente
Esercizio: gestione di un conto corrente Si realizzi un conto corrente bancario mediante: - una ASTRAZIONE DI DATO - un TIPO DI DATO ASTRATTO Il conto corrente è caratterizzato dalle seguenti informazioni:
3.2 Concorrenza, parallelismo e parallelismo reale
3. PROGRAMMAZIONE CONCORRENTE 3.1 Introduzione La programmazione usuale si basa su un modello di esecuzione sequenziale, cioè sull ipotesi che le istruzioni di un programma vengano eseguite una dopo l
I/O su Socket TCP: read()
I/O su Socket TCP: read() I socket TCP, una volta che la connessione TCP sia stata instaurata, sono accedibili come se fossero dei file, mediante un descrittore di file (un intero) ottenuto tramite una
Il Concetto di Processo
Processi e Thread Il Concetto di Processo Il processo è un programma in esecuzione. È l unità di esecuzione all interno del S.O. Solitamente, l esecuzione di un processo è sequenziale (le istruzioni vengono
Dynamic Linking. Introduzione Creazione di una libreria dinamica Uso di una libreria dinamica
Dynamic Linking Introduzione Creazione di una libreria dinamica Uso di una libreria dinamica Dynamic Linking Il linking tra i moduli di un programma e le librerie da esso utilizzate può essere Statico
Tipi di POSIX Semaphores
Semafori POSIX Sono una particolare implementazione dei semafori. Possono svolgere il ruolo di semafori binari o generali (n-ari) a seconda di quale valore viene loro assegnato all'atto della inizializzazione
I THREAD. thread 2. thread 1
I THREAD Un thread è un singolo flusso di istruzioni, all interno di un processo, che lo scheduler può fare eseguire separatamente e concorrentemente con il resto del processo. Per fare questo uno thread
Appunti tratti dal videocorso on-line di Algoritmi e Programmazione Avanzata By ALeXio
Appunti tratti dal videocorso on-line di Algoritmi e Programmazione Avanzata By ALeXio 1-La memoria dinamica La scrittura di un programma (indipendentemente dal linguaggio adottato) deve sempre tener conto
Gestione dei File in C
Gestione dei File in C Maurizio Palesi DIIT Università di Catania Viale Andrea Doria 6, 95125 Catania [email protected] http://www.diit.unict.it/users/mpalesi Sommario In questo documento saranno introdotte
