Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
Abbiamo provato per diverse settimane il nuovo Magic V5 di HONOR, uno smartphone pieghevole che ci ha davvero stupito. Il device è il più sottile (solo 4.1mm) ma non gli manca praticamente nulla. Potenza garantita dallo Snapdragon 8 Elite, fotocamere di ottima qualità e batteria in silicio-carbonio che garantisce un'ottima autonomia. E il Prezzo? Vi diciamo tutto nella nostra recensione completa.
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Google Pixel 10 Pro XL è il top di gamma della serie Pixel, presentando un ampio display Super Actua da 6.8 pollici insieme alle novità della serie, fra cui la ricarica wireless magnetica Pixelsnap e le nuove funzionalità AI avanzate. Il comparto fotografico include un sistema a tripla fotocamera con zoom Pro Res fino a 100x, mentre il processore Tensor G5 con 16GB di RAM garantisce prestazioni percepite molto elevate su Android.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-10-2007, 09:11   #1
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
[Linux C] Emulare WaitForSingleObject con timeout

Ho provato ad emulare la WaitForSingleObject di Windows usando le pThread, ma ci sono riuscito solo in parte.
Il mio obiettivo è quello di bloccare un thread in attesa di un evento, se però la condizione di wait per un qualche motivo viene impostata dopo il signal (in debug avviene praticamente sempre) ottengo un fallimento per timeout, mentre in Windows viene riconosciuto l'evento come già settato e la WaitForSingleObject ritorna subito.

Questo è il codice che ho usato:
Codice:
	class Event
	{
	public:
		Event()
		{
#ifdef WIN32
			event = CreateEvent(NULL,false,false,NULL);
#else
			pthread_cond_init (&event, NULL);
			pthread_mutex_init(&mutex, NULL);
#endif	
		}
		~Event()
		{
#ifdef WIN32
			CloseHandle(event);
#else
			pthread_mutex_destroy(&mutex);
			pthread_cond_destroy(&event);
#endif
		}
		void SetEvent()
		{
#ifdef WIN32
			::SetEvent(event);
#else
			pthread_cond_signal(&event);
#endif
		}
		void ResetEvent()
		{
#ifdef WIN32
			::ResetEvent(event);
#else
			pthread_cond_signal(&event);
#endif
		}

		bool Wait()
		{
#ifdef WIN32
			return WaitForSingleObject(event,INFINITE) == WAIT_OBJECT_0;
#else
			pthread_mutex_lock(&mutex);
			int rc = pthread_cond_wait(&event, &mutex);
			pthread_mutex_unlock(&mutex);
			return rc == 0;
#endif
		}
			
		bool Wait(int milliseconds)
		{
#ifdef WIN32
			return WaitForSingleObject(event,milliseconds) == WAIT_OBJECT_0;
#else
			struct timeval  now;
			struct timespec timeout;
			gettimeofday(&now, NULL);
			timeout.tv_sec = now.tv_sec + milliseconds/1000;
			timeout.tv_nsec = now.tv_usec * 1000;

			bool done = false, success = false;
			int rc = pthread_mutex_lock(&mutex);
			if (rc) /* an error has occurred */
				return false;
			while (!done)
			{
				rc = pthread_cond_timedwait(&event,&mutex,&timeout);
				switch (rc)
				{
				case 0:
					success = true;
					done = true;
					break;
				default:
			            if (rc == ETIMEDOUT)
 			               done = true;
			            break;
				}
			}
			pthread_mutex_unlock(&mutex);
			return success;
#endif
		}
	private:
#ifdef WIN32
		HANDLE event;
#else
		pthread_cond_t event;
		pthread_mutex_t mutex;
#endif
	};
Ok sono pronto alla fucilazione

Un altra domanda ma se volessi attendere sulla pthread_cond_timedwait per 1500 millisecondi devo per forza aggiungere 1 al campo tv_sec e 5e8 a tv_nsec?
Non c'è un modo per aggiungere direttamente il valore a tv_nsec?
Quando ho provato ad aggiungere 15e8 al campo tv_nsec non ho mai raggiunto il timeout.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2007, 10:31   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
fino a qualche mese fa anche io stavo a combattere con questioni del genere, ma ho fatto in maniera molto diversa: non ho cercato più di tanto di uniformare il codice Linux con quello Win32. nel caso specifico degli eventi, portando su Linux ho parzialmente ristrutturato e utilizzato i pthread signals (alla fine IMHO è più facile fare così che non sbattersi ad inventarsi meccanismi di emulazione).
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2007, 13:31   #3
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da 71104 Guarda i messaggi
fino a qualche mese fa anche io stavo a combattere con questioni del genere, ma ho fatto in maniera molto diversa: non ho cercato più di tanto di uniformare il codice Linux con quello Win32. nel caso specifico degli eventi, portando su Linux ho parzialmente ristrutturato e utilizzato i pthread signals (alla fine IMHO è più facile fare così che non sbattersi ad inventarsi meccanismi di emulazione).
Non credo di aver cercato di emulare il comportamento di Windows, mi sembra un criterio di sincornizzazione standard: un thread rimane in wait su una condizione per un certo timeout.
Vorrei capire come fare in modo che una condizione di wait possa terminare con successo se per caso il signal è arrivato prima.
Su Windows questo avviene automaticamente senza problemi, su Linux non sono ancora riuscito ad ottenerlo.

Al momento il codice che ho scritto non mi pare dare alcun problema, però è impossibile debuggare proprio per il fatto che in debug finisce che arriva prima il signal e poi il wait.
tomminno è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli Recensione OnePlus Watch 3 43mm: lo smartwatch c...
Rubati i filmati di oltre 2.000 videocam...
Battlefield 6 sarà molto violento...
Fastweb + Vodafone: arriva la prima offe...
Netflix lancia la possibilità di ...
Digital Foundry elogia il livello tecnic...
Roborock alza l'asticella a IFA 2025: H6...
Instagram: arriva finalmente l'app nativ...
Alpha Trion, Ultra Magnus e Orion Pax: i...
15 anni di Amazon: ecco come ottenere su...
Il nuovo progetto IA di Apple potrebbe e...
La nuova interfaccia di Android non &egr...
Google Pixel: arriva lo streaming audio ...
I nuovi Galaxy Tab S11 sfidano i laptop ...
Samsung lancia Galaxy S25 FE: prezzi e d...
DNS 1.1.1.1 compromesso da certificati f...
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: 13:57.


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