Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-12-2006, 16:34   #1
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
[C] Comunicazione tra padre e figlio

Ciao.

Devo scrivere un programma che legge dal proprio standard input quello che il figlio ha scritto sullo standard output. Il codice che ho scritto io è il seguente:

Codice:
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

int main(){

   pid_t pid;
   int len;
   ssize_t nread;
   ssize_t nwrite;
   int status;

   if( (pid = fork()) < 0)
      perror("fork failed");
   else if( pid == 0){
      char *stringa="Sono il figlio e ho scritto qualcosa";
      len=strlen(stringa);
      if( (nwrite = write(STDOUT_FILENO,stringa,len)) != len){
         if(stringa != NULL){
            free(stringa);
            stringa=NULL;
         }
         perror("write error");
      }
      if(stringa != NULL){
         free(stringa);
         stringa=NULL;
      }
      exit(0);
   }
   else{
      if ( wait(&status) != pid )
         perror("waitpid error");
      char *buf=(char *)malloc(sizeof(char)*100);
      if( (nread = read(STDIN_FILENO,buf,100)) <= 0)
         perror("read failed");
      printf("Adesso dovrei scrivere quello che ha scritto il figlio: ");
      printf("%s", buf);
      if(buf != NULL){
         free(buf);
         buf=NULL;
      }
   }
   printf("Ho finito!!!\n");
   exit(0);
}
Il problema è che una volta che la stringa è stata scritta dal figlio, il programma si ferma (praticamente si ferma alla read del padre) come se fosse in attesa che io gli scrivessi qualcosa. Infatti qualsiasi stringa gli scrivo lui mi stampa quella (e non quella che aveva stampato il figlio su STDOUT). Perché? Spero di essere stato chiaro.

Grazie
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:11   #2
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da Manugal
Ciao.

Devo scrivere un programma che legge dal proprio standard input quello che il figlio ha scritto sullo standard output. Il codice che ho scritto io è il seguente:

Codice:
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

int main(){

   pid_t pid;
   int len;
   ssize_t nread;
   ssize_t nwrite;
   int status;

   if( (pid = fork()) < 0)
      perror("fork failed");
   else if( pid == 0){
      char *stringa="Sono il figlio e ho scritto qualcosa";
      len=strlen(stringa);
      if( (nwrite = write(STDOUT_FILENO,stringa,len)) != len){
         if(stringa != NULL){
            free(stringa);
            stringa=NULL;
         }
         perror("write error");
      }
      if(stringa != NULL){
         free(stringa);
         stringa=NULL;
      }
      exit(0);
   }
   else{
      if ( wait(&status) != pid )
         perror("waitpid error");
      char *buf=(char *)malloc(sizeof(char)*100);
      if( (nread = read(STDIN_FILENO,buf,100)) <= 0)
         perror("read failed");
      printf("Adesso dovrei scrivere quello che ha scritto il figlio: ");
      printf("%s", buf);
      if(buf != NULL){
         free(buf);
         buf=NULL;
      }
   }
   printf("Ho finito!!!\n");
   exit(0);
}
Il problema è che una volta che la stringa è stata scritta dal figlio, il programma si ferma (praticamente si ferma alla read del padre) come se fosse in attesa che io gli scrivessi qualcosa. Infatti qualsiasi stringa gli scrivo lui mi stampa quella (e non quella che aveva stampato il figlio su STDOUT). Perché? Spero di essere stato chiaro.

Grazie
così su due piedi: la read del padre legge STDIN, mentre dovrebbe leggere STDOUT... no?

ora, se questo non fosse possbile (non ricordo) dovresti usare una pipe

Ultima modifica di mad_hhatter : 08-12-2006 alle 18:15.
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:18   #3
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Ho provato a leggere STDOUT ma il risultato è lo stesso. A questo punto del programma non sono ancora arrivato alle pipe, quindi se un esercizio del genere mi viene messo ora che ancora non ho fatto le pipe, sicuramente c'è un metodo per risolverlo senza l'uso delle pipe.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:31   #4
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da Manugal
Ho provato a leggere STDOUT ma il risultato è lo stesso. A questo punto del programma non sono ancora arrivato alle pipe, quindi se un esercizio del genere mi viene messo ora che ancora non ho fatto le pipe, sicuramente c'è un metodo per risolverlo senza l'uso delle pipe.
ma se legge STDOUT non può prendere l'input dalla tastiera

quando fai un fork, il figlio eredita lo stdin e stdout dal padre... forse vanno risettati opportunamente, in modo da risultare scambiati
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:45   #5
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Ma scusa me l'hai detto tu che la read del padre dovrebbe leggere da STDOUT

Quote:
così su due piedi: la read del padre legge STDIN, mentre dovrebbe leggere STDOUT... no?
E' normale infatti che lo faccio leggere da STDIN però non sortisce alcun effetto.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:49   #6
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da Manugal
Ma scusa me l'hai detto tu che la read del padre dovrebbe leggere da STDOUT



E' normale infatti che lo faccio leggere da STDIN però non sortisce alcun effetto.

tu hai detto che leggendo stdout sicomporta allo stesso modo che leggendo stdin... questo non capivo, ora deduco (come è ovvio) che leggendo stdout NON si comporta ESATTAMENTE come quando legge stdin

ma appunto, se gli fai leggere lo stdin non beccherà mai l'output del figlio... se invece nel figlio riesci a invertire i file stdin e stdout sei a posto
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 18:52   #7
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
In che senso invertirli?
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 19:00   #8
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
nel senso che per il processo figlio lo stdout dovrebbe essere rimappato sullo stdin del padre.

quando fai il fork il figlio eredita dal padre lo stdin e lo stdout... se ci fosse un modo per dire al figlio che quello che lui chiama stdout in realtà è lo stdout saremmo aposto... ma leggendo due righe in rete mi par di capire che solo il sistema operativo può scambiare gli IOstream... non so, magari sipuò fare, ma non so come
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 19:50   #9
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Nessuno?
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 21:23   #10
Qu@ker
Member
 
Iscritto dal: Apr 2004
Messaggi: 130
Codice:
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

int main()
{
	int fd[2];
	pid_t pid;
	
	if (pipe(fd) < 0) { 
		perror("pipe"); 
		exit(EXIT_FAILURE);
	}       
	pid = fork();
	if (pid < 0) {
		perror("fork()");
		exit(EXIT_FAILURE);
	}
	if (pid == 0) {
		char *stringa = "Sono il figlio e ho scritto qualcosa";
		int len = strlen(stringa);

		close(fd[0]); //non leggo
		dup2(fd[1], STDOUT_FILENO);
		close(fd[1]);
		if (write(STDOUT_FILENO, stringa, len) < 0) {
			perror("write()");
		}
		_exit(0);
	} else {
		int status;
		char *buf = malloc(100);
		if (! buf) {
			perror("malloc()");
			exit(EXIT_FAILURE);
		}

		close(fd[1]); //non scrivo
		dup2(fd[0], STDIN_FILENO);
		close(fd[0]);
		if (read(STDIN_FILENO, buf, 100) < 0)
			perror("read()");
		printf("Messaggio dal figlio: \'%s\'\n", buf);
		free(buf);

		if (wait(&status) != pid)
			perror("waitpid()");
	}
	puts("Ho finito!!!");
	return 0;
}
Qu@ker è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 21:36   #11
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
scusa, non conosco benissimo il c... hai usato una pipe? se sì, Manugal diceva che non può usarle perchè, credo, al corso che frequenta non gliele hanno introdotte... altre soluzioni?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2006, 09:25   #12
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Devo ancora provarlo per vedere se funziona, però ho trovato una soluzione. Praticamente usando la dup2() faccio una copia STDOUT_FILENO su un nuovo file descriptor in modo da riuscire a leggere con il padre quello che ha scritto il figlio. Ecco il codice:

Codice:
#include <sys/wait.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>

int main(){

   pid_t pid;
   int len;
   ssize_t nread;
   ssize_t nwrite;
   int status;
   int fd;
   
   if ( (fd = open("temp", O_WRONLY | O_CREAT | O_TRUNC)) == -1)
      perror("open failed");

   if( (pid = fork()) < 0)
      perror("fork failed");
   else if( pid == 0){
      char *stringa="Sono il figlio e ho scritto qualcosa";
      len=strlen(stringa);
      if( (nwrite = write(STDOUT_FILENO,stringa,len)) != len){
         if(stringa != NULL){
            free(stringa);
            stringa=NULL;
         }
         dup2(fd,STDOUT_FILENO);
         close(fd);
         perror("write error");
      }
      if(stringa != NULL){
         free(stringa);
         stringa=NULL;
      }
      lseek(fd,0,SEEK_SET);
      exit(0);
   }
   else{
      if ( wait(&status) != pid )
         perror("waitpid error");
      char *buf=(char *)malloc(sizeof(char)*100);
      if( (nread = read(fd,buf,100)) <= 0)
         perror("read failed");
      printf("Adesso dovrei scrivere quello che ha scritto il figlio: ");
      printf("%s", buf);
      if(buf != NULL){
         free(buf);
         buf=NULL;
      }
      close(fd);
   }
   printf("Ho finito!!!\n");
   exit(0);
}
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2006, 09:27   #13
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Ah neanche l'avevo letta la soluzione sopra

In pratica non so se funziona senza pipe.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 09-12-2006, 13:51   #14
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da Manugal
Ah neanche l'avevo letta la soluzione sopra

In pratica non so se funziona senza pipe.
quindi in ogni caso usi un metodo di comunicazione tra processi, non ti affidi ai soli stdin e stdout, giusto?
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2006, 10:31   #15
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Si in un certo senso si è comunicazione tra processi. Però l'uso delle pipe ancora non l'ho introdotto. Ora lo proverò e vedrò se funziona.
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 10-12-2006, 12:01   #16
Manugal
Senior Member
 
L'Avatar di Manugal
 
Iscritto dal: Jan 2001
Città: Villanova di Guidonia (RM)
Messaggi: 1079
Niente da fare anche con quel codice scritto da me poco fa, il programma ha lo stesso comportamento cioè attende che io gli scriva qualcosa (invece di leggere quello che ha scritto il figlio).
Manugal è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2006, 10:14   #17
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Quote:
Originariamente inviato da Manugal
Niente da fare anche con quel codice scritto da me poco fa, il programma ha lo stesso comportamento cioè attende che io gli scriva qualcosa (invece di leggere quello che ha scritto il figlio).
La dup2 la hai inserita un pò "a casaccio", rileggiti il codice copo un caffè

Un pipe è la soluzione corretta. Anche usando dup2 correttamente non puoi avere l'effetto desiderato, per come sono fatti stdin/out.

L'utilizzo di un file temporaneo potrebbe funzionare, ammesso che prima correggi tutti i bug che hai introdotto
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2006, 13:48   #18
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
ecco, speravo proprio in un intervento di ilsensine... mi stavo giusto chiedendo come funzionano stdin/out in linux... hai voglia di illuminarmi perfavore?

grazie mille!
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2006, 14:58   #19
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
ls -l /proc/self/fd

Sono in genere connessi a uno (pseudo)terminale. Quello che ci scrivi, viene letto da chi gestisce il terminale (kernel o programma - tipo console per X - che sia).
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 11-12-2006, 21:47   #20
mad_hhatter
Senior Member
 
L'Avatar di mad_hhatter
 
Iscritto dal: Oct 2006
Messaggi: 1105
Quote:
Originariamente inviato da ilsensine
ls -l /proc/self/fd

Sono in genere connessi a uno (pseudo)terminale. Quello che ci scrivi, viene letto da chi gestisce il terminale (kernel o programma - tipo console per X - che sia).
ma tecnicamente non sono file fisici, bensì cosa? buffer? e se il lettore li svuota ecco che anche se possediamo una copia del loro desrittore non ce ne facciamo nulla... è giusta come ipotesi? se lo è, immagino che sia anche il motivo per cui è indispensabile una pipe perchè essa invia immediatamente i dati al destinatario che quindi li riceve con certezza... è corretto o sto sbagliando?

grazie mille per le info!
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Meta e Broadcom: accordo fino al 2029 pe...
Hai attivato l'opt-out? Google, Meta e M...
Donna denuncia OpenAI: ChatGPT avrebbe a...
Claude Mythos e i test che smontano (sol...
Rockstar Games guadagna ancora cifre eno...
Nasce DIVE - Driving Innovation in Venet...
Fastweb entra tra i partner di Starlink ...
Tesla completa il tape-out del chip AI5:...
App falsa di Ledger Live sull'App Store ...
Svelato il prezzo dell'e-bike che sostit...
ASML vola grazie all'AI: numeri oltre le...
Google lancia l'app nativa per Windows: ...
'Non dovremmo lasciarli entrare nel nost...
Windows 11 25H2 e 24H2, build 26200.8246...
Windows 10, il nuovo aggiornamento estes...
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: 11:53.


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