Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 08-12-2006, 17: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, 19: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 19:15.
mad_hhatter è offline   Rispondi citando il messaggio o parte di esso
Old 08-12-2006, 19: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, 19: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, 19: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, 19: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, 19: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, 20: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, 20: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, 22: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, 22: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, 10: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, 10: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, 14: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, 11: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, 13: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, 11: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, 14: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, 15: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, 22: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 WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
GTA 6 gratis se nasce un figlio il giorn...
Quasi la metà degli smartphone at...
DDR5 a 16 dollari al gigabyte: Framework...
Meno di 3kg per 'diventare' bionici: l'u...
Al regalo di San Valentino ci pensa HUAW...
Intel multata in India: 30 milioni di do...
Beast of Reincarnation ha una data di us...
Provati Reno15 e Reno15 FS: analisi comp...
L'Europa sfida la Cina sul litio: in Fin...
Sono 32, di cui 6 nuove, le offerte Amaz...
Rinnovo dei coupon Amazon nascosti: ecco...
Corsair aggiorna la confezione delle RAM...
Ecco tutti i robot aspirapolvere in offe...
Tachyum: dal processore universale alle ...
L'eVTOL tedesco per missioni mediche e m...
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: 20:19.


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