Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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.
Le soluzioni FSP per il 2026: potenza e IA al centro
Le soluzioni FSP per il 2026: potenza e IA al centro
In occasione del Tech Tour 2025 della European Hardware Association abbiamo incontrato a Taiwan FSP, azienda impegnata nella produzione di alimentatori, chassis e soluzioni di raffreddamento tanto per clienti OEM come a proprio marchio. Potenze sempre più elevate negli alimentatori per far fronte alle necessità delle elaborazioni di intelligenza artificiale.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-03-2011, 17:39   #1
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
[C/C++] File locking tra pthreads

Cercando qua e là non mi è mai capitato di incontrare una funzione equivalente al LockFile di windows, cioè che faccia il lock esclusivo o condiviso tra threads (anche di diversi processi) per i pthreads

Ora, mi trovo ad averne bisogno e mi chiedevo, non c'è proprio niente che faccia al caso mio e sarò costretto a inventarmi improbabili combinazioni di flock (o fcntl, insomma lock dei file tra i processi) e rwlock o c'è qualcosa che posso usare direttamente?
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 28-03-2011, 00:25   #2
Teo@Unix
Senior Member
 
L'Avatar di Teo@Unix
 
Iscritto dal: Mar 2009
Messaggi: 753
Prova a guardarti la struttura pthread_mutex_t e le varie funzioni:
http://linux.die.net/man/3/pthread_mutex_lock
Teo@Unix è offline   Rispondi citando il messaggio o parte di esso
Old 28-03-2011, 01:54   #3
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
ah ecco, perfetto, pthread_rwlockattr_setpshared fa al caso mio, thank you
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 16:37   #4
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
in realtà non fa al caso mio come credevo, per il semplice fatto che è necessario condividere la memoria in cui è allocato il lock per poterlo utilizzare.. ma non c'è una soluzione standard? insomma mi sembra un problema tipico quello di lockare un file, eppure non trovo niente che faccia quel che voglio :/ (cioè l'equivalente di flock, fcntl o lockf per i thread)
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 01-04-2011, 23:14   #5
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
Cercando qua e là non mi è mai capitato di incontrare una funzione equivalente al LockFile di windows, cioè che faccia il lock esclusivo o condiviso tra threads (anche di diversi processi) per i pthreads

Ora, mi trovo ad averne bisogno e mi chiedevo, non c'è proprio niente che faccia al caso mio e sarò costretto a inventarmi improbabili combinazioni di flock (o fcntl, insomma lock dei file tra i processi) e rwlock o c'è qualcosa che posso usare direttamente?
Perche' non puoi usare il solo flock ?
__________________
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 02-04-2011, 13:14   #6
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
perché flock fa mutua esclusione tra i processi, non tra i thread di uno stesso processo, ad esempio

alla fine penso che userò un segmento di memoria condiviso in cui mettere una qualche struttura dati che contiene i miei rwlock indicizzati per numero di inode

a questo proposito, l'ideale sarebbe una std::map.. ma c'è qualche modo per allocare un oggetto dove dico io (nel mio caso, nel segmento che prendo con shmget), e posso essere sicuro che non venga allocato niente al di fuori? ad esempio che non ci siano "new" all'interno, che sarebbero un problema
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 02-04-2011, 16:43   #7
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
perché flock fa mutua esclusione tra i processi, non tra i thread di uno stesso processo, ad esempio
Giusto, me n'ero dimenticato

Quote:
alla fine penso che userò un segmento di memoria condiviso in cui mettere una qualche struttura dati che contiene i miei rwlock indicizzati per numero di inode

a questo proposito, l'ideale sarebbe una std::map.. ma c'è qualche modo per allocare un oggetto dove dico io (nel mio caso, nel segmento che prendo con shmget), e posso essere sicuro che non venga allocato niente al di fuori? ad esempio che non ci siano "new" all'interno, che sarebbero un problema
Se non ricordo male in boost::inteprocess dovrebbe esserci una versione portabile che fa quel che ti serve, senza dover ricorrere a delle mappe.
In ogni caso per il discorso della map dovresti passarle un allocatore tuo (che vada ad allocare dalla memoria condivisa), non una passeggiata.
__________________
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 02-04-2011, 17:12   #8
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
Quote:
Originariamente inviato da marco.r Guarda i messaggi
Giusto, me n'ero dimenticato


Se non ricordo male in boost::inteprocess dovrebbe esserci una versione portabile che fa quel che ti serve, senza dover ricorrere a delle mappe.
In ogni caso per il discorso della map dovresti passarle un allocatore tuo (che vada ad allocare dalla memoria condivisa), non una passeggiata.
intanto ho dimenticato di premettere che è un progetto per un corso di programmazione di sistema (server e client tftp windows e linux) e non posso utilizzare librerie che mi semplifichino il lavoro in questo modo

ok, sembra abbastanza complicato in effetti gestire correttamente la memoria in questo modo.. magari mi conviene usare una più semplice hash table

per altro avrei anche il problema che per fare molte cose (ad esempio inizializzare gli rwlock con pthread_rwlock_t) dovrei lockare il segmento, e mi sembra di capire che non sia proprio un'operazione standard, e comunque richiede i privilegi di root (che potrebbe anche andare bene per il server, ma per il client richiedere i privilegi di root mi sembra esagerato)

ps: soluzioni meno complicate sono sempre molto bene accette

Ultima modifica di tuccio` : 02-04-2011 alle 17:30.
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2011, 14:35   #9
DanieleC88
Senior Member
 
L'Avatar di DanieleC88
 
Iscritto dal: Jun 2002
Città: Dublin
Messaggi: 5989
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
intanto ho dimenticato di premettere che è un progetto per un corso di programmazione di sistema (server e client tftp windows e linux)

Bernaschi?

Io sto lavorando ad un server SMTP/POP con simili caratteristiche, e sono incappato nello stesso problema. Casomai trovassi una buona soluzione lo scriverò qui (o casomai l'abbia trovata tu, condividila ).
__________________

C'ho certi cazzi Mafa' che manco tu che sei pratica li hai visti mai!
DanieleC88 è offline   Rispondi citando il messaggio o parte di esso
Old 24-06-2011, 15:59   #10
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
sì sì, progetto consegnato etc, manca solo la verbalizzazione

Ultima modifica di tuccio` : 24-06-2011 alle 16:44.
tuccio` è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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 ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
iPhone 16 domina il 2025: ecco la classi...
Huawei a supporto delle startup: potenzi...
Iliad è il miglior operatore di l...
Le pompe di calore parlano italiano: Bon...
Moltbot non è solo un chatbot: ag...
Sinner e Alcaraz fermati dall'arbitro: i...
L'audio-video professionale arriva a MIR...
Musk fa i complimenti alla Cina: nel set...
Agcom ha avviato verifiche sul format 'F...
Bose QuietComfort Ultra (2ª Gen) a meno ...
Non è vero niente: H200 in attesa...
Fanatec lancia un nuovo plugin ufficiale...
Anna's Archive vs Spotify: vizio di legg...
Bastano 200 auto elettriche per cambiare...
Tesla rimette le batterie 4680 nella Mod...
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: 16:50.


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