Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-07-2011, 14:26   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
[C/C++] I/O Asincrono

non avendo molto tempo a disposizione per approfondire vi chiedo lumi circa la crittura di file in modo asincrono che coinvolge le API di windows.

Più che altro vorrei delle certezze di stare scrivendo realmente in modo asincrono.

Nel mio programma ho due thread A e B i quali usano la mutua esclusione per evitare che se A sta producendo dati, B non può usarli.

Nel momento in cui A li ha prodotti, B vi accede ed è B che ciclandoli deve scriverli su disco ma non deve rimanere in attesa delle scritture stesse, questo per non perdere tempo.

Da quanto ne ho capito se deve usare la funzione CreateFile() e WriteFile() tirando in ballo la struttura OVERLAPPED ma un esempio funzionale mi sarebbe di grande aiuto.


grazie infinite
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 18:15   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
se volessi poi anche verificare la differenza tra scrittura su disco sincrona ed asincrona come si dovrebbe agire?

grazie
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 18:23   #3
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 21969
da quel poco che mi ricordo, la scrittura su windows è sempre asincrona se non specificato il contrario tanto che in c++ si usava il flush per forzare la scrittura su disco
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 18:26   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da !fazz Guarda i messaggi
da quel poco che mi ricordo, la scrittura su windows è sempre asincrona se non specificato il contrario tanto che in c++ si usava il flush per forzare la scrittura su disco
ciao,
vuoi dire che eventuali ritardi non sono dovute a scritdel ture su disco?

Pensavo che usando le funzioni della libreria standard C le scritture fossero sincrone ed un thread di conseguenza è costretto ad attendere una risposta prima di continuare.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 19:53   #5
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Salve a tutti (primo post per me)!
Quote:
Originariamente inviato da misterx Guarda i messaggi
Pensavo che usando le funzioni della libreria standard C le scritture fossero sincrone ed un thread di conseguenza è costretto ad attendere una risposta prima di continuare.
Quello che dici è giusto (secondo me) nel senso che le scritture (e le letture) sono sincrone se non diversamente specificato. La questione è che, pur essendo sincrone, vengono bufferizzate cioè il SO effettua l'operazione in RAM e solo in seguito (quando lo ritiene opportuno) allinea il contenuto sul disco. Nel caso del multithreading e delle operazioni sincrone è sempre il SO che garantisce ad ogni thread di vedere una copia allineata e consistente. Il problema potrebbe nascere se fai operazioni asincrone e hai bisogno di sapere che l'operazione precedente sia finita prima di procedere con la successiva... ma non mi sembra questo il tuo caso, ho capito bene? Cioè tu vuoi scrivere dei dati e non ti importa di quando verranno veramente salvati su disco giusto?
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 20:06   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da Mettiu_ Guarda i messaggi
Salve a tutti (primo post per me)!


Quello che dici è giusto (secondo me) nel senso che le scritture (e le letture) sono sincrone se non diversamente specificato. La questione è che, pur essendo sincrone, vengono bufferizzate cioè il SO effettua l'operazione in RAM e solo in seguito (quando lo ritiene opportuno) allinea il contenuto sul disco. Nel caso del multithreading e delle operazioni sincrone è sempre il SO che garantisce ad ogni thread di vedere una copia allineata e consistente. Il problema potrebbe nascere se fai operazioni asincrone e hai bisogno di sapere che l'operazione precedente sia finita prima di procedere con la successiva... ma non mi sembra questo il tuo caso, ho capito bene? Cioè tu vuoi scrivere dei dati e non ti importa di quando verranno veramente salvati su disco giusto?
ciao,
hai capito perfettamente.
Ho un thread produttore che fa la scansione di un certo numero di sensori ed un thread consumatore che nel momento in cui si accorge che un dato sensore ha cambiato il suo stato, scrive alcuni dati su disco.
Il mio problema è che lavorando in termini di millisecondi, si nota un certo ritardo, a volte, ed altre nò intorno ai 50 ms o poco più.

Tale ritardo credo sia dovuto proprio alle scritture su disco date dal fatto che quando il thread consumatore scrive su disco, attende la completa scrittura prima di continuare il suo lavoro.

Da qui il problema di scrivere dati su disco in modo asincrono in modo che il thread consumatore continui indistrurbato il suo lavoro senza attese.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 20:25   #7
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Se i dati da scrivere sono pochi non ti conviene usare l' I/O asincrono perchè è vero che il consumatore torna subito disponibile ma è anche vero che gestire un I/O sovrapposto da parte del SO comporta comunque un overhead che nel caso di piccoli moli di dati non si ammortizza. Per provare ad avere tempi di scrittura quantomeno deterministici potresti flushare i tuoi dati su disco dopo ogni scrittura sincrona e vedere se almeno così ottieni tempi costanti. Se non li ottieni (o sono comunque troppo alti), probabile che hai esigenze di real-time troppo spinte per essere risolte così...

Documentazione MSDN: http://msdn.microsoft.com/en-us/libr...8VS.85%29.aspx
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 20:37   #8
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da Mettiu_ Guarda i messaggi
Se i dati da scrivere sono pochi non ti conviene usare l' I/O asincrono perchè è vero che il consumatore torna subito disponibile ma è anche vero che gestire un I/O sovrapposto da parte del SO comporta comunque un overhead che nel caso di piccoli moli di dati non si ammortizza. Per provare ad avere tempi di scrittura quantomeno deterministici potresti flushare i tuoi dati su disco dopo ogni scrittura sincrona e vedere se almeno così ottieni tempi costanti. Se non li ottieni (o sono comunque troppo alti), probabile che hai esigenze di real-time troppo spinte per essere risolte così...

Documentazione MSDN: http://msdn.microsoft.com/en-us/libr...8VS.85%29.aspx
se fosse determinabile il ritardo forse raggiungerei l'ottimo!
A questo punto dovrei abbandonare le funzioni della libreria standard per usare quelle messe a disposizione da windows ?

Non ho conoscenze nella programmazione real-time purtroppo.

Però: se dovessi mandare in esecuzione n volte il medesimo programma per catturare n sensori da n fonti differenti cosa comporterebbe nei vari ritardi scrivendo e "flushando" ogni volta ?

Avrei in esecuzione n processi e 2n thread e forse non me ne dovrei occupare in quanto ci penserebbe windows?

In questo caso è meglio scrivere dati in modo asincrono?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 21:30   #9
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Quote:
Originariamente inviato da misterx Guarda i messaggi
se fosse determinabile il ritardo forse raggiungerei l'ottimo!
Il determinismo non credo lo si possa ottenere perchè dipende da troppe cose non direttamente controllabili (carico del sistema in un certo momento, politiche di scheduling, ecc...).

Quote:
Originariamente inviato da misterx Guarda i messaggi
Però: se dovessi mandare in esecuzione n volte il medesimo programma per catturare n sensori da n fonti differenti cosa comporterebbe nei vari ritardi scrivendo e "flushando" ogni volta ?

Avrei in esecuzione n processi e 2n thread e forse non me ne dovrei occupare in quanto ci penserebbe windows?

In questo caso è meglio scrivere dati in modo asincrono?
Comporterebbe che ad ogni scrittura il SO va sul disco a scrivere e, poichè questo è unico, non può parallelizzare le scritture ma dovrà farle comunque sequenzialmente, senza grossi vantaggi teoricamente. In altri casi può decidere di accumulare un pò di dati e poi scriverli tutti in un colpo solo migliorando l'efficienza (secondo lui). Se però il tuo problema è che non tolleri latenza cioè non tolleri che passi troppo tempo da quando il dato è a disposizione del consumatore a quando questo è disponibile sul file (scritto), allora bisogna capire bene quali sono i parametri che vuoi ottimizzare. E' più importante avere scritto un dato prima possibile a partire da quando questo è stato reso disponibile dal produttore o è meglio migliorare l'efficienza del disco scrivendo più dati in un colpo solo (e quindi aspettandone un certo numero)? Se questi dati arrivano solo "ogni tanto" (rispetto ai tempi della cpu) io farei delle scritture sincrone con flush e mi rimetterei subito in attesa di nuovi dati (il file lo apri una volta sola all'inizio del programma e lo chiudi una volta sola alla fine)...
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 06:51   #10
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
diciamo che il mio problema maggiore è conoscere con precisione tutte le tempistiche. Se la scrittura su disco sottrae un certo tempo devo tenerne conto ma dovrei sapere con precisione quanto tempo spendo per tale operazione in modo da poterlo sottrarre/sommare al tempo di variazione di stato dei vari sensori.

Già poter dire che flush()+scrittura=50 ms sempre sarebbe un'ottima soluzione.


Codice:
#include <stdio.h>

int main()
{
   char miastringa[40];
   FILE *stream = fopen("miofile.txt","a");
   printf("Inserisci meno di 40 caratteri -> ");
   fscanf(stdin, "%s", miastringa);
   fprintf(stream, "La mia stringa e' : %sn", miastringa);
   fflush(stream);
   fclose(stream);
}
però anche in questo caso devo attendere la scrittura ed è ancora windows a decidere credo. E quindi quando richiamola fflush() potrei determinare il tempo speso scrivendo:

t1=tempo_start()
fflush()
t2=tempo_end()

tempo_totale=t2-t1;

Sempre che i due tempi mi vengano calcolati al momento della chiamata; ma se anche qui windows interviene in modo random allora non c'è soluzione.

Ultima modifica di misterx : 05-07-2011 alle 07:39.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 09:34   #11
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da misterx Guarda i messaggi
ciao,
hai capito perfettamente.
Ho un thread produttore che fa la scansione di un certo numero di sensori ed un thread consumatore che nel momento in cui si accorge che un dato sensore ha cambiato il suo stato, scrive alcuni dati su disco.
Il mio problema è che lavorando in termini di millisecondi, si nota un certo ritardo, a volte, ed altre nò intorno ai 50 ms o poco più.

Tale ritardo credo sia dovuto proprio alle scritture su disco date dal fatto che quando il thread consumatore scrive su disco, attende la completa scrittura prima di continuare il suo lavoro.

Da qui il problema di scrivere dati su disco in modo asincrono in modo che il thread consumatore continui indistrurbato il suo lavoro senza attese.
Se il thread consumatore ci mette troppo a scrivere nelle occasioni in cui il S.O. deve fare il flush dei buffer, probabilmente fai prima a cambiare il metodo di comunicazione tra i due thread. Se, come mi sembra di ricordare, utilizzi una memoria condivisa tra i due thread, con accesso sincronizzato, i ritardi del consumatore si ripercuotono nel produttore.
Devi ricorrere ad un metodo diverso che faccia da buffer e accumuli i dati in eccesso nelle occasioni in cui il consumatore si prende indietro.
Non so di preciso sotto windows, ma alternative dovresti averne piu' di una (socket, pipe e forse anche altro)
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 16:43   #12
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Quote:
Originariamente inviato da misterx Guarda i messaggi
diciamo che il mio problema maggiore è conoscere con precisione tutte le tempistiche. Se la scrittura su disco sottrae un certo tempo devo tenerne conto ma dovrei sapere con precisione quanto tempo spendo per tale operazione in modo da poterlo sottrarre/sommare al tempo di variazione di stato dei vari sensori.

però anche in questo caso devo attendere la scrittura ed è ancora windows a decidere credo. E quindi quando richiamola fflush() potrei determinare il tempo speso scrivendo:

t1=tempo_start()
fflush()
t2=tempo_end()

tempo_totale=t2-t1;

Sempre che i due tempi mi vengano calcolati al momento della chiamata; ma se anche qui windows interviene in modo random allora non c'è soluzione.
Ho provato fare una cosa del genere sul mio pc per vedere se ne esce fuori un calcolo sensato:
Codice:
#include <stdlib.h>
#include <Windows.h>

int _tmain(int argc, _TCHAR* argv[])
{
	SYSTEMTIME start, end;

	FILE* fp = fopen("prova.dat", "w+");
	
	char* text = "Questo è un testo di prova da scrivere sul file";
	if(fp == NULL)
		exit(-1);

	GetSystemTime(&start);
	fprintf(fp, text);
	fflush(fp);
	GetSystemTime(&end);
	
	printf("Ora avvio scrittura: %dsec %dmilliSec", start.wSecond, start.wMilliseconds);
	printf("\nOra fine scrittura: %dsec %dmilliSec", end.wSecond, end.wMilliseconds);
	printf("\nTempo impiegato per la scrittura: %d\n", end.wMilliseconds - start.wMilliseconds);
        fclose(fp);
	system("PAUSE");
	return 0;
}
L' output prodotto è:
Codice:
Ora avvio scrittura: 16sec 614milliSec
Ora fine scrittura: 16sec 615milliSec
Tempo impiegato per la scrittura: 1ms
Ti sembra possibile? E' realistico come tempo?
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 17:11   #13
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da Mettiu_ Guarda i messaggi
Ho provato fare una cosa del genere sul mio pc per vedere se ne esce fuori un calcolo sensato:
Codice:
#include <stdlib.h>
#include <Windows.h>

int _tmain(int argc, _TCHAR* argv[])
{
	SYSTEMTIME start, end;

	FILE* fp = fopen("prova.dat", "w+");
	
	char* text = "Questo è un testo di prova da scrivere sul file";
	if(fp == NULL)
		exit(-1);

	GetSystemTime(&start);
	fprintf(fp, text);
	fflush(fp);
	GetSystemTime(&end);
	
	printf("Ora avvio scrittura: %dsec %dmilliSec", start.wSecond, start.wMilliseconds);
	printf("\nOra fine scrittura: %dsec %dmilliSec", end.wSecond, end.wMilliseconds);
	printf("\nTempo impiegato per la scrittura: %d\n", end.wMilliseconds - start.wMilliseconds);
        fclose(fp);
	system("PAUSE");
	return 0;
}
L' output prodotto è:
Codice:
Ora avvio scrittura: 16sec 614milliSec
Ora fine scrittura: 16sec 615milliSec
Tempo impiegato per la scrittura: 1ms
Ti sembra possibile? E' realistico come tempo?
ciao,
gran bella prova
Se ripetuto almeno un migliaio di volte ripete il medesimo valore allora sarebbe attendibile.
Però proverei anche lanciando diverse istanze dello stesso programma per vedere cosa accade, quindi si ritroverebbe a lavorare su n file simultaneamente.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 18:42   #14
Mettiu_
Member
 
L'Avatar di Mettiu_
 
Iscritto dal: Jul 2011
Messaggi: 246
Quote:
Originariamente inviato da misterx Guarda i messaggi
ciao,
gran bella prova
Se ripetuto almeno un migliaio di volte ripete il medesimo valore allora sarebbe attendibile.
Però proverei anche lanciando diverse istanze dello stesso programma per vedere cosa accade, quindi si ritroverebbe a lavorare su n file simultaneamente.
Anche se fai un while da 10000 e stampi su file, le varie durate sono sempre 0-1 ms! Mai al di sopra.
Mettiu_ è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 18:53   #15
!fazz
Moderatore
 
L'Avatar di !fazz
 
Iscritto dal: Nov 2006
Messaggi: 21969
occhio che windows e real time non vanno per nulla d'accordo
__________________
"WS" (p280,cx750m,4790k+212evo,z97pro,4x8GB ddr3 1600c11,GTX760-DC2OC,MZ-7TE500, WD20EFRX)
Desktop (three hundred,650gq,3800x+nh-u14s ,x570 arous elite,2x16GB ddr4 3200c16, rx5600xt pulse P5 1TB)+NB: Lenovo p53 i7-9750H,64GB DDR4,2x1TB SSD, T1000
!fazz è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 20:21   #16
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da Mettiu_ Guarda i messaggi
Anche se fai un while da 10000 e stampi su file, le varie durate sono sempre 0-1 ms! Mai al di sopra.
e se esegui simultaneamente 10 volte lo stesso programma?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2011, 21:01   #17
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da !fazz Guarda i messaggi
occhio che windows e real time non vanno per nulla d'accordo
lo stavo pensando, difatti se scrivo

t1=timer_start
fflush()
t2=timer_end

facendo t2-t1 di sicuro il tempo è corretto però non so quando windows mi stampa il risultato in quanto anch'esso, le sue righe di codice, è soggetto a ritardi che si riflettono poi sul thread consumatore



http://msdn.microsoft.com/it-it/libr...27.aspx#ID0EGC

http://msdn.microsoft.com/en-us/libr...bedded.5).aspx

Ultima modifica di misterx : 06-07-2011 alle 06:35.
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
La Cina vieta ufficialmente le maniglie ...
HP e lavoro ibrido: le nuove cuffie Poly...
MSI sta lavorando a un dissipatore ottim...
27 offerte Amazon, le prime 5 in elenco ...
Il telescopio spaziale James Webb ha cre...
Il reboot di Painkiller tenta il rilanci...
7 smartphone in super offerta su Amazon,...
Ring abbassa i prezzi su Amazon: videoci...
Blink taglia i prezzi su Amazon: Mini 2K...
Claude al centro di Apple: ecco come Cup...
Pornhub e altri siti porno si ribellano ...
La TV non è smart? Amazon la trasforma c...
Oltre 200 siti di news hanno limitato l'...
Gennaio si chiude positivamente per il m...
Caos in Ubisoft: licenziato un dipendent...
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: 15:21.


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