Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere)
Quattro modi di indossarlo, stessa app del Plaud Note Pro e integrazione con il desktop. Il registratore IA da indossare di Plaud eccelle in mobilità, ma resta vincolato all'abbonamento ed è facile da perdere
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro
Xiaomi ha portato Redmi Watch 6 anche sul mercato italiano, puntando su un display AMOLED da 2,07 pollici con picco di luminosità a 2000 nit, frame in alluminio da 9,9mm e un'autonomia dichiarata di 12 giorni. Lo smartwatch gira su HyperOS 3 e integra GPS, Bluetooth 5.4 e oltre 150 sport mode. Il tutto a meno di 100 euro
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti
Con 22 tasti, il pulsante 5D, lo Shift Mode e il sensore PixArt 3395 da 26.000 DPI, il nuovo mouse wireless di Mad Catz si rivolge in modo preciso ai giocatori di MMO e RPG. Ma chi conosce già il R.A.T. 8+ ADV si accorgerà subito di quanto i due prodotti condividano, e di dove invece divergono
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


Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Redmi Watch 6 in prova: lo smartwatch con ampio display da 2000 nit a meno di 100 euro Redmi Watch 6 in prova: lo smartwatch con ampio ...
Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ADV, ma con molti più pulsanti Mad Catz M.M.O. 7+: lo stesso DNA del R.A.T. 8+ ...
Radeon RX 9070 GRE, AMD la porta in tutto il mondo | Recensione Gigabyte Gaming OC Radeon RX 9070 GRE, AMD la porta in tutto il mon...
Reolink OMVI 3i WiFi: videosorveglianza più intelligente e facile da usare Reolink OMVI 3i WiFi: videosorveglianza pi&ugrav...
La battaglia delle HBM4 entra nel vivo: ...
Dopo 12 anni torna Alien: Isolation. Ecc...
ADATA Trusta ridurrà i costi di i...
SpaceX fornirà 110.000 GPU NVIDIA...
Hyundai IONIQ 6 N-Line, prova in antepri...
Sospesi i lavori di riparazione delle pe...
Formula V vi farà cambiare l'airf...
Netflix usa l'IA generativa per battere ...
Quando l'AI costruisce sé stessa:...
Meno ventole, più raffreddamento:...
Adidas Trionda: come funziona la tecnolo...
Withings BodyFit, la bilancia che va ben...
QNAP annuncia QuTS hero h6.0: il sistema...
ColorOS 17 con Android 17: la lista dei ...
DDR4, il ritorno che nessuno si aspettav...
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: 07:55.


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