Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-01-2007, 10:33   #1
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
[C] Scrittura concorrente in file

Salve,
mi domandavo come fare per far scrivere contemporaneamente a più processi nello stesso file binario. Ho provato a dire ad ogni processo di scrivere nel file posizionando il puntatore con fseek, solo che ogni volta ovviamente il file viene sovrascritto dall'ultimo processo che arriva. Grazie.

Ultima modifica di Unrue : 02-01-2007 alle 10:35.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 11:16   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Unrue
mi domandavo come fare per far scrivere contemporaneamente a più processi nello stesso file binario. Ho provato a dire ad ogni processo di scrivere nel file posizionando il puntatore con fseek, solo che ogni volta ovviamente il file viene sovrascritto dall'ultimo processo che arriva. Grazie.
Far scrivere a più processi sullo stesso file ma in punti diversi non credo che sia un problema (dovrei comunque verificare bene).
Mentre invece il problema esiste sicuramente per scritture contemporanee nello stesso punto.
In ogni caso sarebbe meglio fare un lock del file (o di una parte del file, se è possibile), fare le modifiche, e poi togliere il lock.
Comunque quando passa di qui qualcuno più esperto sull'argomento, saprà dirti sicuramente meglio.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:24   #3
Johnn
Senior Member
 
Iscritto dal: May 2004
Messaggi: 1136
Non consideratemi esperto, ma non si avrebbero problemi anche nella scrittura contemporanei in punti diversi per il fatto che non sarebbe più coerente la posizione?

Io avrei detto di usare i semafori, o comunque un qualsiasi strumento di mutua esclusione.
Johnn è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:30   #4
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Quote:
Originariamente inviato da Johnn
Non consideratemi esperto, ma non si avrebbero problemi anche nella scrittura contemporanei in punti diversi per il fatto che non sarebbe più coerente la posizione?

Io avrei detto di usare i semafori, o comunque un qualsiasi strumento di mutua esclusione.
In che senso non sarebbe più coerente la posizione?
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:31   #5
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Quote:
Originariamente inviato da andbin
Far scrivere a più processi sullo stesso file ma in punti diversi non credo che sia un problema (dovrei comunque verificare bene).
Mentre invece il problema esiste sicuramente per scritture contemporanee nello stesso punto.
In ogni caso sarebbe meglio fare un lock del file (o di una parte del file, se è possibile), fare le modifiche, e poi togliere il lock.
Comunque quando passa di qui qualcuno più esperto sull'argomento, saprà dirti sicuramente meglio.
In realtà a me va bene anche che scriva uno per volta, ovviamente in punti diversi.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:38   #6
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Johnn
Non consideratemi esperto, ma non si avrebbero problemi anche nella scrittura contemporanei in punti diversi per il fatto che non sarebbe più coerente la posizione?
La posizione all'interno del file è legata al "handle" (o descrittore, come vuoi chiamarlo) aperto dal processo. Non è una cosa "globale"

Quote:
Originariamente inviato da Johnn
Io avrei detto di usare i semafori, o comunque un qualsiasi strumento di mutua esclusione.
No ... come farebbero le applicazioni A (sviluppata da Tizio) e B (sviluppata da Caio) a sapere che per accedere, in modo esclusivo, ad uno stesso file, si devono usare dei semafori, mutex o altro???
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:49   #7
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19149
esattamente come devono avvenire le scritture? devi posizionarti in un punto preciso o basta che tu scriva alla fine del file ogni volta?
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:54   #8
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
in Win32 esiste l'overlapped I/O, che supporta già da solo tutta la sincronizzazione necessaria a risolvere il problema.

EDIT - no scusate, non vorrei aver detto una boiata, controllo meglio...
EDIT2 - boh, non è che sia esplicitato molto bene, ma mi pare di aver capito che se una lettura overlapped avviene contemporaneamente a una scrittura overlapped, i dati letti non sono "inconsistenti"; mentre se le due non operazioni fossero overlapped i dati letti potrebbero essere inconsistenti.

Ultima modifica di 71104 : 02-01-2007 alle 15:07.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 14:58   #9
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da 71104
in Win32 esiste l'overlapped I/O, che supporta già da solo tutta la sincronizzazione necessaria a risolvere il problema.
L'overlapped I/O è solo .... un I/O asincrono (le funzioni ritornano subito e il risultato ... successivamente). Non ha nulla a che fare con la concorrenza nella scrittura o con il locking.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 15:09   #10
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da andbin
L'overlapped I/O è solo .... un I/O asincrono (le funzioni ritornano subito e il risultato ... successivamente). Non ha nulla a che fare con la concorrenza nella scrittura o con il locking.
credo che la sincronizzazione per evitare l'inconsistenza delle operazioni di I/O sia una conseguenza dell'implementazione dell'overlapped I/O, ma in effetti è meglio non farci affidamento. per definizione l'unica garanzia che ti da' l'overlapped I/O è il poter ricevere in un secondo momento la notifica di terminazione di operazioni lunghe.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2007, 15:50   #11
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Quote:
Originariamente inviato da recoil
esattamente come devono avvenire le scritture? devi posizionarti in un punto preciso o basta che tu scriva alla fine del file ogni volta?
No, in un punto preciso, devo scriverci una matrice.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 10:33   #12
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Ho scritto questo:

Codice:
void scrivi_file(float**matrice_trasposta_locale,int lx,int dim_mat,int me)
    {  
      struct flock fl;
      int fd;
      off_t offset;
      int ris;
      fl.l_type= F_WRLCK;  /* tipo di lock*/
      fl.l_whence = SEEK_SET; /* offset */
      fl.l_start  = 0;        /* Offset per l_whence         */
      fl.l_len    = 0;        /* length, 0 = to EOF           */
     fl.l_pid    = getpid(); /* our PID                      */
	  
	  
	  fd = open("home/gabriele/Desktop/output", O_WRONLY);  //fd è il Descrittore del file
	  
	  
	  fcntl(fd, F_SETLKW, &fl);  // Attendi per avere il lock
	  lseek(fd, dim_mat*lx*me*sizeof(float),fl.l_whence);
      int i;
      int j;
      
      
      for(j=0;j<lx;j++)
      	{ 
              for(i=0;i<dim_mat;i++)
      	        {   
                         printf(" Sono arrivato  : %d \n",me);
      			ris=write(fd,&matrice_trasposta_locale[i][j],1);
      		printf("Valore :  %2.1f da %d \n ",matrice_trasposta_locale[i][j],me);
      		printf("Risultato: %d \n",ris);		 
      		}
      	}
      		
      fl.l_type   = F_UNLCK;  
      fcntl(fd, F_SETLK, &fl);
      
     
    
    }
La cosa strana è che le scritture avvengono a video correttamente, ma nel file non scrive,infatti la write ritorna sempre -1

Ultima modifica di Unrue : 03-01-2007 alle 10:44.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 10:44   #13
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Unrue
La cosa strana è che le scritture avvengono a video correttamente, ma il file non c'è!!
Verifica bene la documentazione di open()!
Codice:
fd = open("home/gabriele/Desktop/output", O_WRONLY | O_CREAT);
Mettendo solo O_WRONLY, la open fallisce se il file non esiste già. Con O_CREAT, se non c'è, lo crea.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 10:52   #14
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Grazie del suggerimento,però open continua a ritornarmi -1 Sono sotto Linux, forse c'è un problema di permessi per scrivere nella cartella?
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 10:58   #15
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Unrue
Grazie del suggerimento,però open continua a ritornarmi -1 Sono sotto Linux, forse c'è un problema di permessi per scrivere nella cartella?
Beh, verifica bene il path! Visto così suppongo che debba essere:

/home/gabriele/Desktop/output
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 11:06   #16
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Ma por... vero . Adesso il primo processo che arriva apre il file e ci scrive,però gli altri che vengono dopo ritornano -1 sempre alla open. L'attesa per prendere il lock la fa la fcntl con F_SETLKW, non capisco.. Sembra che gli altri non attendano di prendere il lock ed escano subito.
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 11:14   #17
Unrue
Senior Member
 
L'Avatar di Unrue
 
Iscritto dal: Nov 2002
Messaggi: 6851
Ho capito perchè: il primo processo crea il file. Ma tale file non ha permessi di scrittura. Ho provato a metterci un file vuoto ed a dare tutti i permessi in scrittura e lettura ed adesso tutti ci scrivono,strano però..
Unrue è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 11:33   #18
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Stavo leggendo adesso la documentazione di fcntl(). F_GETLK, F_SETLK e F_SETLKW sono definiti "Advisory locking". Vuol dire che non gestiscono un reale blocco "forzato" sul file. Vanno bene solo quando i processi "cooperano" insieme, cioè sanno di dover lavorare su un file comune e quindi effettuano questo tipo di lock.

Per dirla in breve: apri un file di testo con la open(), fai il lock e poi prova, da un altro prompt, a fare echo "blabla" > file. Vedrai che la echo scrive sul file. Tu pensi: ma l'ho bloccato!! Sì ma echo non "coopera" e non usa fcntl per fare il lock.

In definitiva: usare F_GETLK, F_SETLK e F_SETLKW non ti para il sedere da qualunque altro processo che vuole scrivere sul file.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 11:48   #19
Johnn
Senior Member
 
Iscritto dal: May 2004
Messaggi: 1136
Quote:
Originariamente inviato da andbin
La posizione all'interno del file è legata al "handle" (o descrittore, come vuoi chiamarlo) aperto dal processo. Non è una cosa "globale"

No ... come farebbero le applicazioni A (sviluppata da Tizio) e B (sviluppata da Caio) a sapere che per accedere, in modo esclusivo, ad uno stesso file, si devono usare dei semafori, mutex o altro???
Premetto che non ho tanto tempo, quindi post frettoloso.

La prima parte mi convince, parzialmente però quando ho tempo mi documenterò meglio, comunque ok.

La seconda, come anche è ripetuto nell'ultimo post, non l'ho capita: nel senso che motivo c'è di essere cautelati da scritture di processi non previsti? Non mi pare sia richiesto da Unrue. Se si volesse così, penso si debba pensare su due livelli: uno di mutua esclusione e un altro di controllo di accesso al file (permessi?).
Johnn è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2007, 12:09   #20
beppegrillo
Senior Member
 
L'Avatar di beppegrillo
 
Iscritto dal: Mar 2004
Messaggi: 1455
Quote:
Originariamente inviato da Johnn
Premetto che non ho tanto tempo, quindi post frettoloso.

La prima parte mi convince, parzialmente però quando ho tempo mi documenterò meglio, comunque ok.
Su Os *unix, la cosa è gestita mediante due tabelle, una di tipo globale in cui vi sono fisicamente i dati e l'altra di tipo utente che recupera le informazioni da quella globale e ne possiede di proprie (ad. es offset)
Per questo motivo se esegui scritture con processi diversi, non apriranno due volte lo stesso file, ma ciascun vedrà il file come proprio.
__________________
Ciao ~ZeRO sTrEsS~
beppegrillo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
The Duskbloods potrebbe arrivare a fine ...
Il miglior pesce d'aprile del mondo Linu...
Monopattini elettrici a 62 km/h fermati ...
OpenAI porta la modalità vocale d...
Mercedes-Benz introduce lo steer-by-wire...
Hacker agli Uffizi, il museo smentisce: ...
Nvidia mostra il futuro della grafica co...
Windows 11, scattano gli aggiornamenti f...
TIM lancia l'offerta di Pasqua: Giga ill...
Prime foto reali per OPPO Find X9 Ultra:...
Il leak di Claude Code diventa un'esca: ...
Netflix, batosta in Italia: aumenti ille...
UFO e complotti: chi si cela dietro la n...
Batterie EV difficili da riciclare: il p...
Non vuoi targare il monopattino? Engwe h...
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:37.


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