Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming
Questo mouse ultraleggero, con soli 36 grammi di peso, è stato concepito per offrire un'esperienza di gioco di alto livello ai professionisti degli FPS, grazie al polling rate a 8.000 Hz e a un sensore ottico da 33.000 DPI. La recensione esplora ogni dettaglio di questo dispositivo di gioco, dalla sua agilità estrema alle specifiche tecniche che lo pongono un passo avanti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-02-2003, 16:39   #1
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Ancora read e write su socket in C

Sto di nuovo sotto il mio programmozzo...devo spedire da A a B un pacchetto, ho deciso di spedire prima una sorta di header che dice quanto e' lungo il pacchetto che poi spedisco dopo l'header. Ho fatto 2 funzioni, ma non so perche' l'header arriva, ma poi quando deve ricevere il pacchetto chi spedisce si ferma in un: write() failed [err 104]: Connection reset by peer mentre chi riceve piglia sto errore: read() failed [err 14]: Bad address

i 2 codici sono questi prima chi spedisce:

Codice:
int sendData(int socketfd, char msg[MAXSIZE])
{
        long nwrite, len, n;

        /* scrittura */
        len=strlen(msg);
        nwrite=0;

        do
        {
                if ((n=write(socketfd, &len, (HEADERSIZE-nwrite)))<0)
                {
                        if (errno!=EINTR)
                        {
                                char msgerror[1024];
                                sprintf(msgerror,"write() failed [err %d]",errno);
                                perror(msgerror);
                                fflush(stderr);

                                return(1);
                        }
                }
                else
                        nwrite+=n;
        } while (nwrite<HEADERSIZE);

        nwrite=0;

        while ((len-nwrite)>0)
        {
                if ((n=write(socketfd, &(msg[nwrite]), (len-nwrite)))<0)
                {
                        if (errno!=EINTR)
                        {
                                char msgerror[1024];
                                sprintf(msgerror,"write() failed [err %d]",errno);
                                perror(msgerror);
                                fflush(stderr);

                                return(1);
                        }
                }
                else
                        nwrite+=n;
        }

        return(0);
};
chi riceve invece ha:
Codice:
int receiveHeaderAndData(int socketfd, char *msg)
{
        long n,nread,header;

        nread=0;

        do
        {
                if ((n=read(socketfd, &header, (HEADERSIZE-nread)))<0)
                {
                        if (errno!=EINTR)
                        {
                                char msgerror[1024];
                                sprintf(msgerror,"read() failed [err %d]",errno);
                                perror(msgerror);
                                fflush(stderr);
                                return(1);
                        }
                }
                else
                        nread+=n;
        } while (nread<HEADERSIZE);

        nread=0;

        printf("\n\nSocketfd: %d:  header: %ld\n\n",socketfd,header);

        while ((header-nread)>0)
        {
                if ((n=read(socketfd, &(msg[nread]), (header-nread)))<0)
                {
                        if (errno!=EINTR)
                        {
                                char msgerror[1024];
                                sprintf(msgerror,"read() failed [err %d]",errno);
                                perror(msgerror);
                                fflush(stderr);
                                return(1);
                        }
                }
                else
                        nread+=n;
        }

        return(0);
}
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 16:51   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Io direi prima di tutto di cambiare i cicli di lettura in questo modo :
Codice:
        do
        { 
                //Nota il 3o parametro della write
                if ((n=write(socketfd, &len, HEADERSIZE-nwrite))<0) 
                { 
                        if (errno!=EINTR) 
                        { 
                                char msgerror[1024]; 
                                sprintf(msgerror,"write() failed [err %d]",errno); 
                                perror(msgerror); 
                                fflush(stderr); 

                                return(1); 
                        } 
                } 
                else nwrite+=n; 
        } while(nwrite == HEADERSIZE)
Ora prova anche se non credo che sia quello l'errore...
Ah anche durante la lettura del messaggio devi emttere header-nread...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 17:00   #3
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Quote:
Originally posted by "cionci"

Io direi prima di tutto di cambiare i cicli di lettura in questo modo :
Codice:
        do
        { 
              ...

        } while(nwrite == HEADERSIZE)
Ora prova anche se non credo che sia quello l'errore...
Ah anche durante la lettura del messaggio devi emttere header-nread...
Beh se metto il do while devo mettere != e non ==
Inoltre anche if ((n=read(socketfd, &header, HEADERSIZE))<0) devo mettere (HEADERSIZE-nread) ?
In ogni caso non funzia...
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 17:10   #4
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Ho modificato il post iniziale con le nuove funzioni...HELP ME!
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 17:40   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Hai ragione su ==. Metti comunque < non != non si testa mai il diverso su un incremento altrimenti in qualche modo (magari per sbaglio) potresti rischiare di andare in ciclo

Riguardo all'errore...boh... Magari me lo guardo meglio...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 17:50   #6
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Quote:
Originally posted by "cionci"

Hai ragione su ==. Metti comunque < non != non si testa mai il diverso su un incremento altrimenti in qualche modo (magari per sbaglio) potresti rischiare di andare in ciclo

Riguardo all'errore...boh... Magari me lo guardo meglio...
Ok fatta la modifica del while!
Odio quando non riesco a capire il perche' delle cose -> ->
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2003, 21:25   #7
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Eh eh eh...ilsensine ne sa una in piu' del diavolo...o forse sono io che non ne so ancora abbastanza?
Beh l'importante e' aver messo a posto il tutto
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2003, 07:33   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ehm...dov'è il post di ilsensine ? Dov'era il problema...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2003, 09:26   #9
Cimmo
Senior Member
 
L'Avatar di Cimmo
 
Iscritto dal: Jan 2001
Città: California
Messaggi: 7174
Quote:
Originally posted by "cionci"

Ehm...dov'è il post di ilsensine ? Dov'era il problema...
Diciamo che l'ho impezzato da un'altra parte
Prima di tutto mi ha fatto mettere sizeof(len) e sizeof(header) nei primi 2 while delle funzioni e poi il problema era che il chiamante della funzione read non allocava la stringa cioe' la dichiaravo cosi': char *msg; e invece lui la voleva dichiarata cosi': char msg[MAXSIZE]; Non capisco perche' la prima dichiarazione funziona in certi altri casi, ma questa volta no...ok non e' allocato lo spazio, ma il C non dovrebbe allocarlo quando ci scrivi?
Cimmo è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2003, 11:25   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Ecco perchè non andava !!!!
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Vanguard 96 e Vanguard Pro 96: Corsair f...
Cisco Sovereign Critical Infrastructure:...
Flyoobe supporta anche Windows 11 25H2: ...
Roborock Saros 10 e 10R: i robot aspirap...
Assetto Corsa EVO 0.3 rilasciato: debutt...
Dongfeng si presenta all'Italia: tutti i...
PlayStation 5 Slim con lettore Blu-ray s...
Windows 10: supporto esteso gratuito in ...
Xiaomi Pad 8 e Pad 8 Pro ufficiali: disp...
Advanced Shader Delivery per combattere ...
Il calore di una vetreria riciclato per ...
Amazon non si ritiene colpevole ma paga ...
Xiaomi 17 Series è ufficiale: i P...
ROG Xbox Ally e Ally X: Microsoft e ASUS...
Amazon taglia i prezzi della serie LG OL...
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: 10:58.


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