Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Peugeot Polygon Concept: ecco il futuro delle utilitarie
Peugeot Polygon Concept: ecco il futuro delle utilitarie
Polygon è la concept car di Peugeot che mostra il futuro delle soluzioni del segmento B: tra design compatti e innovativi affiancati da dimensioni compatte uno scherzo dalla manovrabilità incredibile per le manovre a bassa velocità
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 11-06-2014, 13:53   #1
B-jo
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 1345
[C]Consiglio su semafori per sincronizzazione di due task

Volevo avere un parere su l'implementazione di due semafori per sincronizzare la lettura di una risorsa che viene continuamente aggiornata.


la mia situazione è che task1 e task2 leggono una variabile che un task3 aggiorna. Dovrei trovare il modo di far leggere ai due task lo stesso valore nel caso in cui uno dei due dovesse essere schedulato in maniera diversa

Avevo pensato di fare cosi con due mutex letto a 0 e possoleggere a 1
Task1
wait su possoleggere
legge la risorsa
signal su possoleggere
signal su letto

Task2
wait su possoleggere
wait su letto
legge la risorsa
signal possoleggere
signal su letto

il task3 invece non puo' essere toccato per specifiche date...

Secondo voi concettualmente è corretto?
B-jo è offline   Rispondi citando il messaggio o parte di esso
Old 11-06-2014, 18:22   #2
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Dalla descrizione non e' chiaro se task3 ha gia' un meccanismo di sincronizzazione o di notifica dell'aggiornamento della variabile.

Il tuo pseudocodice e' un po' strano, ma forse quello strano sono io. Perche' due signal su possoleggere e letto?

La mia proposta e' piu' semplice: altro thread, chiamiamolo dispatcher. Sarebbe opzionale ma concettualmente e' piu' carino.
Dispatcher legge da thread 3, ed ha bisogno di farlo una sola volta. Poi spedisce il valore letto ai due thread, ciascuno affacciato ad una coda/pipe/socket/memoria condivisa/array sincronizzato/...

per capirci, il thread dispatcher fara':
while (!finito)
{
val = leggi_valore(); /* Supponiamo che resti bloccato qui fino al prossimo valore */
send(queue1, val);
send(queue2, val);
}

Ovviamente se non vuoi introdurre un nuovo thread, puoi assegnare questo lavoro ad uno degli altri due (i.e. legge e spedisce all'altro).

Probabilmente e' lo stesso, ma mi sembra piu' semplice e 'pulito' da gestire...
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 11-06-2014, 19:44   #3
B-jo
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 1345
Quote:
Originariamente inviato da sottovento Guarda i messaggi
Dalla descrizione non e' chiaro se task3 ha gia' un meccanismo di sincronizzazione o di notifica dell'aggiornamento della variabile.

Il tuo pseudocodice e' un po' strano, ma forse quello strano sono io. Perche' due signal su possoleggere e letto?

Innanzitutto grazie per la risposta.
In realtà sono io che ho semplificato troppo la spiegazione del mio problema quindi credo che sia io quello strano xDxD


Ti spiego meglio la problematica. Allora ho un task3 che non posso toccare perchè simula un sensore in un processo che mi aggiorna costantemente i valori di un ipotetico sistema.
Ora ho due task che devono leggere i valori contemporaneamente dalla variabile in comune perchè rappresentano i dispositivi incaricati di acquisire i valori dal sensore.

Il mio problema è che se capita una schedulazione particolare, devo far in modo che i due task adibiti all'acquisizione leggano lo stesso valore. Tutto ciò senza toccare il task "sensore"



Quote:
La mia proposta e' piu' semplice: altro thread, chiamiamolo dispatcher. Sarebbe opzionale ma concettualmente e' piu' carino.
Dispatcher legge da thread 3, ed ha bisogno di farlo una sola volta. Poi spedisce il valore letto ai due thread, ciascuno affacciato ad una coda/pipe/socket/memoria condivisa/array sincronizzato/...
Per risolvere il problema mi è stato detto o di usare due semafori (come ho provato a fare io e di cui non so nemmeno se ho implementato bene xD) oppure di far comunicare i due task di acquisizione come se ho intuito bene mi hai proposto tu giusto?


Quote:
per capirci, il thread dispatcher fara':
while (!finito)
{
val = leggi_valore(); /* Supponiamo che resti bloccato qui fino al prossimo valore */
send(queue1, val);
send(queue2, val);
}
Mi hanno detto proprio di far comunicare i due task dicendo al task1 di acquisizione di mandare il valore letto al task2.
Quote:
Probabilmente e' lo stesso, ma mi sembra piu' semplice e 'pulito' da gestire...
Si secondo me è più pulito questo qui.
Ti ringrazio perchè non riuscivo ad elaborare una soluzione con questo tipo di suggerimento che mi hanno dato!

Adesso provo ad implementarlo e ti faccio sapere se sono riuscito nell'intento!!
B-jo è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2014, 11:18   #4
B-jo
Senior Member
 
Iscritto dal: Dec 2005
Messaggi: 1345
Alla fine ho risolto come mi hai consigliato solo che ho dovuto fare alcune modifiche per rispettare alcune specifiche che mi erano state date....

Grazie mille!!!
B-jo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Peugeot Polygon Concept: ecco il futuro delle utilitarie Peugeot Polygon Concept: ecco il futuro delle ut...
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
MOVA LiDAX Ultra 800 è un robot tagliaer...
iPhone 17 256GB oggi torna a soli 849€ s...
Dyson V8 Cyclone (aspira) scontata di 15...
Edge AI: NVIDIA Jetson raggiungerà...
La missione robotica LINK per salvare il...
Potrebbe essere stato lanciato l'ultimo ...
PamStealer, il malware per Mac che prima...
NAVEE EXO S Pro, il robot esoscheletro p...
Samsung Galaxy A57 5G a 399€ con 256 GB:...
Volevano collegare delle aragoste vive a...
La crisi dei PC è peggiore del pr...
Alibaba pronta a vietare Claude Code ai ...
Sovranità sui dati: Cloud Firewal...
FiberCop porterà la fibra Gigabit...
Data center in Lombardia: 20 progetti sc...
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: 07:03.


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