Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-10-2011, 10:32   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
[C/C++] Socket

ciao,
sto usando le socket per un programma e mi sono accorto di non aver compreso bene il funzionamento.

Ho preso in affitto del codice Client e del Codice server per Borland Builder 6.0 e ne è venuto fuori una cosa del tipo:

Server
void __fastcall TForm1::FormCreate(TObject *Sender)
{
ServerSocket1->Port = 5000;
ServerSocket1->Active = True;
}

questo quando viene lanciato il programma e suppongo che il server rimanga sempre in ascolto

void __fastcall TForm1::ServerSocket1ClientConnect(TObject *Sender,
TCustomWinSocket *Socket)
{
Socket->SendText(Edit1->Text);
}
questo evento invece quando un client si connette

per sperimentare poi ho voluto aggiungere questo semplice codice in un Button

void __fastcall TForm1::Button1Click(TObject *Sender)
{
for(int i=0; i < 5; i++)
{
Sleep(1000);
Form1->ServerSocket1->Socket->SendText(i);
}
}

Quello che ottengo è un funzionamento corretto fino al Welcome e un disallineamento tra Client/Server quando clicco sul pulsante.

Nel client il codice è il seguente:
void __fastcall TForm1::FormCreate(TObject *Sender)
{
ClientSocket1->Port = 5000;
ClientSocket1->Host = "127.0.0.1";
ClientSocket1->Active = True;
}
allo start del client

void __fastcall TForm1::ClientSocket1Connect(TObject *Sender,
TCustomWinSocket *Socket)
{
if( ClientSocket1->Active )
Edit1->Text = Socket->ReceiveText();
}
quando il client si connette al server


void __fastcall TForm1::ClientSocket1Read(TObject *Sender,
TCustomWinSocket *Socket)
{
if( ClientSocket1->Active )
Edit1->Text = ClientSocket1->Socket->ReceiveText();
}

quando il server invia al client dei messaggi



Cosa è sbagliato concettualemnte in questo codice?
Non è forse vero che una volta che il client ha creato una connessione attende messaggi dal server?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 12:47   #2
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12944
Se stai sotto Windows immagino che ti convenga dare un'occhiata alle API WinSock2.

http://msdn.microsoft.com/en-us/libr...=VS.85%29.aspx

Nota: queste sono le API native del SO.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 13:22   #3
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Qualche suggerimento:

Quote:
void __fastcall TForm1::FormCreate(TObject *Sender)
Non usare l'evento OnCreate in C++, usa il costruttore del form.

Quote:
Codice:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
        for(int i=0; i < 5; i++)
        {
                Sleep(1000);
                Form1->ServerSocket1->Socket->SendText(i);
        }
}
No, lato server devi inviare il testo per ogni connessione attiva, per esempio:

Codice:
    for (int i = 0; i < ServerSocket1->Socket->ActiveConnections; i++)
    {
        ServerSocket1->Socket->Connections[i]->SendText(String(i));
    }
Quote:
Codice:
void __fastcall TForm1::ClientSocket1Connect(TObject *Sender,
      TCustomWinSocket *Socket)
{
        if( ClientSocket1->Active )
                Edit1->Text = Socket->ReceiveText();
}
E perchè appena si connette vai a leggere?

Quote:
Codice:
void __fastcall TForm1::ClientSocket1Read(TObject *Sender,
      TCustomWinSocket *Socket)
{
        if( ClientSocket1->Active )
                Edit1->Text = ClientSocket1->Socket->ReceiveText();
}
Questo mi pare corretto, anche se forse l'if è ridondante.

HTH,
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 13:53   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Se stai sotto Windows immagino che ti convenga dare un'occhiata alle API WinSock2.

http://msdn.microsoft.com/en-us/libr...=VS.85%29.aspx

Nota: queste sono le API native del SO.
grazie 1000, e ho già usate per atri scopi ,a ora avendo la semplificazione dei componento in BCB vorrei almeno scrivere codice più breve e già testato.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 13:55   #5
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Qualche suggerimento:



Non usare l'evento OnCreate in C++, usa il costruttore del form.



No, lato server devi inviare il testo per ogni connessione attiva, per esempio:

Codice:
    for (int i = 0; i < ServerSocket1->Socket->ActiveConnections; i++)
    {
        ServerSocket1->Socket->Connections[i]->SendText(String(i));
    }


E perchè appena si connette vai a leggere?



Questo mi pare corretto, anche se forse l'if è ridondante.

HTH,

scusa in questo caso

ServerSocket1->Socket->Connections[i]->SendText(String(i));

devo conoscere il numero di connessioni attive giusto?
Non ho trovato una cosa del tipo: ServerSocket1->Socket->Connections[i]->Count();

Il messaggio quando si connette era solo un esperimento.



p.s.
credo di aver trovato Label1->Caption=ServerSocket1->Socket->ActiveConnections;

Ultima modifica di misterx : 17-10-2011 alle 14:02.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 14:10   #6
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
p.s.
credo di aver trovato Label1->Caption=ServerSocket1->Socket->ActiveConnections;
Sì, beh, c'era anche nel mio esempio...
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 17-10-2011, 14:11   #7
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Sì, beh, c'era anche nel mio esempio...
scusa ma mi era sfuggito


grazie 1000
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 09:14   #8
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Qualche suggerimento:



Non usare l'evento OnCreate in C++, usa il costruttore del form.
scusa mi ero dimenticato di chiederti il motivo della tua affermazione

ciao
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 09:32   #9
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
scusa mi ero dimenticato di chiederti il motivo della tua affermazione
E' una cosa abbastanza risaputa e puoi trovare diversi riferimenti in rete, soprattutto nei newsgroup Borland/Codegear, ad esempio qui: http://groups.google.com/group/borla...76e30a2eb68d1c
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 15:25   #10
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
grazie per la dritta.

Ho ancora unda domanda: come gestisco le disconnessioni del client in quanto ottengo il messaggio "esocketerror ......... 1053"?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:10   #11
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
come gestisco le disconnessioni del client in quanto ottengo il messaggio "esocketerror ......... 1053"?
Beh per questo non c'è una risposta univoca, dipende molto dal codice, da cosa fa il programma, da come vuoi gestire gli errori in genere e dalla situazione che ha portato all'errore. In linea di massima l'evento OnClientDisconnect dovrebbe esserti utile.

Però bisognerebbe anche capire dove lo ottieni quel messaggio di errore (che credo sia 10053, non 1053). In generale ci sono gli eventi OnClientError/OnError, però potrebbe servirti anche qualche try/catch...
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:18   #12
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Beh per questo non c'è una risposta univoca, dipende molto dal codice, da cosa fa il programma, da come vuoi gestire gli errori in genere e dalla situazione che ha portato all'errore. In linea di massima l'evento OnClientDisconnect dovrebbe esserti utile.

Però bisognerebbe anche capire dove lo ottieni quel messaggio di errore (che credo sia 10053, non 1053). In generale ci sono gli eventi OnClientError/OnError, però potrebbe servirti anche qualche try/catch...
sto ancora sperimentando e mantenendo fede al codice iniziale

Codice:
    for (int i = 0; i < ServerSocket1->Socket->ActiveConnections; i++)
    {
        ServerSocket1->Socket->Connections[i]->SendText(String(i));
    }
quando il programma client viene chiuso si ha la comparsa dell'errore giustamente da te corretto 10053.

So che si poteva gestire attraverso try/catch ignorando l'errore nel senso di:


Codice:
    for (int i = 0; i < ServerSocket1->Socket->ActiveConnections; i++)
    {
        try {
                ServerSocket1->Socket->Connections[i]->SendText(String(i));
           } catch(...) { } // ignora l'eccezione e continua
    }
ma non sembra la soluzione migliore in quanto il messaggio di errore viene mostrato comunque.

Ultima modifica di misterx : 18-10-2011 alle 16:27.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:37   #13
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
Codice:
    for (int i = 0; i < ServerSocket1->Socket->ActiveConnections; i++)
    {
        try {
                ServerSocket1->Socket->Connections[i]->SendText(String(i));
           } catch(...) { } // ignora l'eccezione e continua
    }
Nel codice iniziale l'invio della stringa avveniva alla pressione di un pulsante. Se è ancora così, non dovresti avere alcun tipo di errore poichè la disconnessione del client (se effettuata correttamente) è gestita in automatico. Altrimenti spiega meglio come ottieni l'errore. try/catch in quella circostanza non serve.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:44   #14
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Nel codice iniziale l'invio della stringa avveniva alla pressione di un pulsante. Se è ancora così, non dovresti avere alcun tipo di errore poichè la disconnessione del client (se effettuata correttamente) è gestita in automatico. Altrimenti spiega meglio come ottieni l'errore. try/catch in quella circostanza non serve.

Il pulsante esegue(lancia) una funzione ed in luogo di un for() c'è un while() che continua ad invare dati all'infinito a chi si connette.
Se il client si disconnette sia ha errore 10053.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:48   #15
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
Il pulsante esegue(lancia) una funzione ed in luogo di un for() c'è un while() che continua ad invare dati all'infinito a chi si connette.
Se il client si disconnette sia ha errore 10053.
Dalla descrizione non mi sembra un granchè, ma senza vedere il codice aiutarti è piuttosto arduo.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 16:57   #16
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
rimedio subito

//client
Codice:
void __fastcall TForm1::FormCreate(TObject *Sender)
{
        ClientSocket1->Port = 5000;
        ClientSocket1->Host = "127.0.0.1";
        ClientSocket1->Active = True;
}
//---------------------------------------------------------------------------

void __fastcall TForm1::FormClose(TObject *Sender, TCloseAction &Action)
{
        ClientSocket1->Active = False;
}
//---------------------------------------------------------------------------
void __fastcall TForm1::FormDestroy(TObject *Sender)
{
        ClientSocket1->Active = False;
}
//---------------------------------------------------------------------------


void __fastcall TForm1::ClientSocket1Connect(TObject *Sender,
      TCustomWinSocket *Socket)
{
        if( ClientSocket1->Active )
                Edit1->Text = Socket->ReceiveText();
}
//---------------------------------------------------------------------------

void __fastcall TForm1::ClientSocket1Read(TObject *Sender,
      TCustomWinSocket *Socket)
{
        if( ClientSocket1->Active )
                Edit1->Text = ClientSocket1->Socket->ReceiveText();

server
Codice:
bool bAbort;
void test(void);
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
        : TForm(Owner)
{
}
//---------------------------------------------------------------------------

void __fastcall TForm1::FormCreate(TObject *Sender)
{
        ServerSocket1->Port = 5000;
        ServerSocket1->Active = True;
        bAbort = false;
}
//---------------------------------------------------------------------------

void __fastcall TForm1::FormClose(TObject *Sender, TCloseAction &Action)
{
        ServerSocket1->Active = False;
}
//---------------------------------------------------------------------------

void __fastcall TForm1::ServerSocket1ClientConnect(TObject *Sender,
      TCustomWinSocket *Socket)
{
        Socket->SendText(Edit1->Text);
}
//---------------------------------------------------------------------------

void __fastcall TForm1::Button1Click(TObject *Sender)
{
       bAbort = false;
       test();
}
//---------------------------------------------------------------------------
void test(void)
{
int i=0;
        while(bAbort == false)
        {
                for(int actconn = 0; actconn < Form1->ServerSocket1->Socket->ActiveConnections; actconn++)
                        Form1->ServerSocket1->Socket->Connections[actconn]->SendText(String("connessione numero: ") + String(i++));
                                Application->ProcessMessages();

        }
}
//---------------------------------------------------------------------------

void __fastcall TForm1::Button2Click(TObject *Sender)
{
        bAbort = true;
}
//---------------------------------------------------------------------------
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 17:17   #17
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
rimedio subito


Vedo che gli errori già segnalati ci sono ancora, quindi non so quanto possa essere utile, ad ogni modo il problema dell'errore 10053 è che stai inviando continuamente una marea di dati verso i client, quindi è altamente probabile che la disconnessione avvenga durante uno di questi invii. L'evento OnClientError (che già ti avevo indicato) non è gestito e pertanto ti viene visualizzato l'errore.

A parte quello, se stai facendo solo qualche prova veloce d'accordo, altrimenti ti suggerirei di rivedere bene tutto il codice e di pensare ad un'architettura migliore (leggasi: multithreading o timer, in base a cosa devi fare).
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 17:43   #18
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
sto ancora effettuando delle prove, gli errori verranno corretti dopo. Comunque non ho idea di come gestire l'evento che mi suggerisci, non ho molta esperienza con questa parte della programmazione.

Qua mi ci vuole il manuale del 6.0

Ultima modifica di misterx : 18-10-2011 alle 18:27.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-10-2011, 19:33   #19
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
ho scoperto come gestire l'evento OnClientError

Codice:
void __fastcall TForm1::ServerSocket1ClientError(TObject *Sender,
      TCustomWinSocket *Socket, TErrorEvent ErrorEvent, int &ErrorCode)
{
        if (ErrorCode == 10053)
	{
	         Socket->Close();
	}

        ErrorCode = 0;
}
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
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...
La Toyota Yaris avrà una versione...
Minori sessualizzati da Grok: l'UE mette...
NIO stabilisce il nuovo record di scambi...
Dell Private Cloud sempre più ape...
Ennesimo incidente per la guida autonoma...
Dopo le maniglie, è il turno dei ...
Addio incendi incontrollati? Svolt dice ...
WINDTRE si mette in proprio: vender&agra...
The Mandalorian & Grogu: il trailer ...
OpenClaw sotto attacco: i malware infost...
Resident Evil Requiem: pre-load dal 25 f...
Vaticano, la Messa si traduce in 60 ling...
Kia prepara il facelift della Kia EV5: n...
La nuova Alpine A110 elettrica sfrutterà...
Il nuovo entry level della gamma MacBook...
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: 18:35.


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