Torna indietro   Hardware Upgrade Forum > Software > Programmazione

L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026
La parola d'ordine al Nextcloud Summit 2026, che si è tenuto a Monaco, è stata "sovranità". Non come è spesso usato questo termine in politica ma, al contrario, come capacità positiva di decidere il proprio destino tecnologico, con modalità collaborative e aperte. L'Europa dice già molto nel mondo open source, che viene visto come mezzo per ottenere la tanto agognata autonomia digitale
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-06-2010, 14:57   #1
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
Impossibile leggere da stdin con una fgets da dentro un thread..!

Salve a tutti,
pongo un problema alquanto strano.. da main io do vita ad un thread incaricato di leggere dallo standard input. Queste letture gliele faccio fare con una fgets() ma, ovviamente, non mi funge.. ^^
L'eccezione a runtime è la seguente:
*** glibc detected *** ./msgcli: munmap_chunk(): invalid pointer: 0xbfc64570 ***

Posto il pezzetto di codice della funzione che esegue il thread alla creazione:
Codice:
static void* senderJob(void *arg) {
	char line[MESSAGE_MAX_LENGTH];
	
	while(1) {
		if(fgets(line, MESSAGE_MAX_LENGTH, stdin) == NULL) SEND_EXIT(1, "Error while reading from standard input")
		...
        }
Ho verificato che il problema si verifica proprio per colpa di 'stdin'... I thread di un medesimo processo non condividono tutti la tabella dei file aperti?
Non dovrebbe essere un problema, quindi, poter leggere da standard input...

Qualcuno ha qualche idea brillante??

Thanks a lot...
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 15:43   #2
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Su che piattaforma sei ? Come crei il thread ?
__________________
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 17-06-2010, 15:55   #3
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
ciao..
si, scusa.. non ho dato questo tipo di informazioni..
Sono su kubuntu.. per la creazione del thread utilizzo la system call relativa ai thread POSIX pthread_create(). Ti scrivo anche il codice della chiamata:

Codice:
static void* senderJob(void *);
...
main() {
    pthread_t sender;
    int socket;
    ...
    if(pthread_create(&sender, NULL, senderJob, (void *)&socket) != 0) MAIN_EXIT(1, "Error when creating the sender thread");
    ...
}
Grazie comunque per avermi risposto..
Ciao
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 16:48   #4
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da galele87 Guarda i messaggi
ciao..
si, scusa.. non ho dato questo tipo di informazioni..
Sono su kubuntu.. per la creazione del thread utilizzo la system call relativa ai thread POSIX pthread_create(). Ti scrivo anche il codice della chiamata:

Codice:
static void* senderJob(void *);
...
main() {
    pthread_t sender;
    int socket;
    ...
    if(pthread_create(&sender, NULL, senderJob, (void *)&socket) != 0) MAIN_EXIT(1, "Error when creating the sender thread");
    ...
}
Grazie comunque per avermi risposto..
Ciao
La creazione sembra a posto. Per caso usi fgets in piu' thread ? In tal caso potrebbe trattarsi di accesso condiviso a strutture dati interne (anche se mi sembra strano, fgets mi sembrava fosse reentrant, o comunque dovrebbe provvedere pthread.h a far si' che lo sia ).
Se cosi' fosse puoi fare una verifica compilando con -D_REENTRANT

Che versione di kubuntu e di gcc stai usando ?
__________________
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 17-06-2010, 17:15   #5
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
Allora..
non conoscevo l'opzione -D REENTRANT.. =)
Non so come interpretare il risultato ma la compilazione con questa opzione non mi fornisce alcuna stampa sul terminale.. comunque il codice appartiene ad un (per ora) semplice client e son sicuro di usare la fgets() soltanto in quella occasione.

La versione del kernel di ubuntu è 2.6.31-19, mentre la versione del compilatore è
- gcc version 4.4.1 (Ubuntu 4.4.1-4ubuntu9)

Grazie dell'aiuto.. sto provando ancora a cercare in giro ma con nulli risultati..

Novità.. se apporto questa modifica (particolarmente brutta devo dire) il tutto sembra funzionare:
definisco una variabile globale

Codice:
static FILE *fp standard_input;
poi, nel thread main, assegno a standard_input lo stdin e faccio una fgets a vuoto

Codice:
standard_input = stdin;
fgets(line, MESSAGE_MAX_LENGTH, standard_input);
Adesso, la stessa fgets(line, MESSAGE_MAX_LENGTH, standard_input) dal thread sembra funzionare... ci capisci qualcosa? =)

Ultima modifica di galele87 : 17-06-2010 alle 17:23.
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 17:19   #6
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da galele87 Guarda i messaggi
Allora..
non conoscevo l'opzione -D REENTRANT..
Occhio non e' "-D REENTRANT" ma "-D_REENTRANT" con un underscore tra i due ( quando usi -D il nome della macro da definire va appiccicata e in questa caso il nome e' proprio _REENTRANT)
__________________
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 17-06-2010, 17:25   #7
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
Ah ok, scusa la svista..
cmq niente, stessi risultati di prima (nessuna stampa)..
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 17:29   #8
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
No, chiedo scusa..
non funziona più neanche così.. ^^

Non ho parole
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 17:50   #9
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
Ho provato anche a bloccare il flusso che rappresenta lo standard input, per poterci accedere esclusivamente da un thread. Le funzioni POSIX sono
- flockfile(FILE *stream);
- funlockfile (FILE *stream);

Il problema sussiste..

...invalid pointer....
galele87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2010, 19:50   #10
galele87
Junior Member
 
Iscritto dal: Jun 2010
Messaggi: 10
Ok, trovato..
scusa per averti fatto perdere tempo.. in effetti era un problema di free ma non era dentro al thread.. ma nel thread main..

Grazie mille per avermi aiutato
Scusa di nuovo



(che svista scema.. )
galele87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Engwe O20 Boost: abbiamo provato in ante...
UWANT V800: addio al rullo rotante, l’as...
Keenetic Stellar 6 porta il WiFi 6 negli...
Instagram spinge sul formato orizzontale...
DMA, l'UE verso la designazione di AWS e...
Dalla fisica quantistica alla fibra: il ...
TikTok, il 59% dei video è AI Slop, 'sch...
Batterie stampate in 3D: la forma libera...
Honor X80 Pro Max ufficiale: vi bastano ...
HONOR Watch 6: batteria infinita, modali...
Windows 11, addio alle ricerche sul web:...
La vera sfida dell’IA non è adott...
Signal contro l'AI agentica: dare ai cha...
Amazon: l'human-in-the-loop non basta a ...
HONOR 600 Lite: design in metallo e batt...
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: 19:54.


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