Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2007, 09:45   #1
LOVE85
Member
 
Iscritto dal: Jun 2006
Messaggi: 86
Processi con semafori URGENTE!!!!!!

Sincronizzazione di 3 Processi coi Semafori.
Si considerino i processi A, B e C che si sincronizzano come
mostrato nel seguito attraverso i semafori Sem1, Sem2 e Sem3
(inizializzati a 0) e che operano sulle variabili condivise x, y e z. Che
sono inizializzate come segue: x = 1; y = 2; z = 1;
Con quale ordine i processi stampano i valori delle tre variabili?
Qual è il valore delle tre variabili che viene infine stampato?

Process A {
P(Sem1);
z = (x - z)*y ;
x = x+z+y;
V(Sem3);
P(Sem1);
x = x + y;
Print(x);
}

Process C {
V(Sem2);
P(Sem3);
x = x / y ;
y = 2z + x ;
V(Sem1);
z = x + z;
Print(z);
}

Process B {
P(sem2);
x = x + y;
z = x - z;
y=(y-z)+x;
Print(y);
V(sem1);
}
E' vero che stampa prima y,poi z e infine x?

E' vero che mi stampano i seguenti valori?
x = 5
y = 3
z = 3/2

I processi si influenzano tra di loro?
Cioè quando acquisiscono le variabili inizializzate esse unavolta elaborate dal processo vengono passate o solo utilizzate per stampare ogni variabile? Grazie. mI SERVE PER CAPIRE CHE DOMANI HO STA PROVAA!!!
LOVE85 è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2007, 13:23   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ad occhio V è equivalente ad una signal e P ad una wait...in tal caso:

- l'unico processo che non si blocca all'inzio è C, ma si blocca su P(Sem3) avendo prima sbloccato B con V(Sem2).
- a questo punto B esegue i calcoli e stampa y e sblocca A
- A esegue i calcoli sblocca C e si blocca su Sem1
- C esegue i calcoli e sblocca A

Ora la situazione è strana ci sono due processi in esecuzione contemporaneamente...non essendoci mutua esclusione e lavorando sulle stesse variabili (che secondo il testo sono appunto condivise), il risultato non è predicibile.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2007, 16:37   #3
giannola
Senior Member
 
L'Avatar di giannola
 
Iscritto dal: Oct 2005
Città: Palermo
Messaggi: 2579
Quote:
Originariamente inviato da cionci Guarda i messaggi
Ad occhio V è equivalente ad una signal e P ad una wait...in tal caso:

- l'unico processo che non si blocca all'inzio è C, ma si blocca su P(Sem3) avendo prima sbloccato B con V(Sem2).
- a questo punto B esegue i calcoli e stampa y e sblocca A
- A esegue i calcoli sblocca C e si blocca su Sem1
- C esegue i calcoli e sblocca A

Ora la situazione è strana ci sono due processi in esecuzione contemporaneamente...non essendoci mutua esclusione e lavorando sulle stesse variabili (che secondo il testo sono appunto condivise), il risultato non è predicibile.
esatto C dovrebbe sbloccare A solo dopo aver eseguito tutti i calcoli e stampato, altrimenti per la race condition, la z potrebbe avere valori diversi.
Va da sè che i due processi non sarebbero in esecuzione contemporaneamente come afferma il buon cionci.
Uno sarebbe in esecuzione e l'altro sarebbe nella coda dei processi pronti, però appunto non si può predire in questo modo quale dei due a causa di una interruzione o della scadenza del suo quanto di tempo sia in grado di essere completato prima.

Ipotesi 1:

C fa la sua signal su sem1 e continua a lavorare, in questo caso
z sarà uguale a x+z, poi però si può interrompere e parte A che eseguirà
x=x+y e magari continua e stampa x.

Ipotesi 2:

C fale stesse cose di cui sopra però arriva a terminare e dunque riuscirà a stampare z

Ipotesi 3 (la più dannosa):

C fa la signal su sem1 e viene sospeso, a questo punto A esegue x=x+z e magari si interrompe.

Ora quando C riprende non avrà più un operazione z=x+z, ma è z=(x+y)+z.

Tralasciando le precedenze sulla stampa che possono ancora in questo caso essere influenzate a seconda che subentrino altre interruzioni o no, è grave che proprio il risultato della variabile globale z possa essere fondamentalmente modificato.
__________________
Utente gran figlio di Jobs ed in via di ubuntizzazione
Lippi, perchè non hai convocato loro ?
giannola è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2007, 17:03   #4
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Non è detto che non siano in esecuzione contemporaneamente...in un ambiente multiprocessore (che è solitamente la supposizione che si fa per questo genere di problemi, cioè il worst case) potrebbero essere in esecuzione anche contemporaneamente

Ultima modifica di cionci : 18-02-2007 alle 17:06.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2007, 18:30   #5
giannola
Senior Member
 
L'Avatar di giannola
 
Iscritto dal: Oct 2005
Città: Palermo
Messaggi: 2579
Quote:
Originariamente inviato da cionci Guarda i messaggi
Non è detto che non siano in esecuzione contemporaneamente...in un ambiente multiprocessore (che è solitamente la supposizione che si fa per questo genere di problemi, cioè il worst case) potrebbero essere in esecuzione anche contemporaneamente
Già, dimenticavo l'ambiente multiprocessore
Davo per scontato che si limitasse al monoprocessore.

EDIT: aggiungo che lo davo per scontato proprio perchè si parlava delle wait, che da sole in ambiente multiprocessore non possono esistere, perchè per essere eseguite bisognerebbe disabilitare le interruzioni su tutti i processori, sul multiprocessore occorre utilizzare le tsl.
Ecco perchè mi ero risolto al solo aspetto monoprocessore.
__________________
Utente gran figlio di Jobs ed in via di ubuntizzazione
Lippi, perchè non hai convocato loro ?

Ultima modifica di giannola : 19-02-2007 alle 07:28.
giannola è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2007, 20:20   #6
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da giannola Guarda i messaggi
Già, dimenticavo l'ambiente multiprocessore
Davo per scontato che si limitasse al monoprocessore.
semi-ot: indipendentemente dal numero di processori e dalle specificità dell'architettura, quando si ragiona con le teorie di programmazione concorrente va definito quali operazioni sono atomiche e quali non lo sono. possono esistere architetture multiprocessore sulle quali sono atomiche operazioni che non lo sono su altre (sempre multiprocessore), e viceversa.
71104 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
GoPro annuncia la linea MISSION 1 con tr...
Alcune varianti dei futuri Samsung Galax...
Il ridimensionamento di OnePlus in Europ...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
OnePlus ci riprova con la fascia bassa: ...
La Top 10 delle offerte Amazon del weeke...
XGIMI MoGo 2 Pro a 339€: Google TV con N...
Forum IT & Intelligence 2026: dall'A...
iPhone 16e per la prima volta a meno di ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 03:11.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v