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 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


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
La nuova Alpine A110 elettrica sfrutterà...
Il nuovo entry level della gamma MacBook...
Panasonic 55'' QLED con Dolby Vision e F...
TOP 250 PLUS e TOP 300 PLUS ritornano: v...
Incentivi auto elettriche, si va verso r...
Crimson Desert non è un Soulslike...
Sostituzione caldaia con nuovi sistemi, ...
La Germania verso il divieto e il ban de...
Questo super TV Samsung OLED da 65'' con...
Android Auto 16.3 svela due segreti di G...
Apple Podcasts introduce video con HLS e...
Gli iPhone 17, 17 Pro e 16e sono conveni...
Sentite l'Agenzia delle Entrate: le e-bi...
Recensione Synology DS1825+: 8 hard disk...
App IO: i numeri del portafoglio digital...
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: 14:29.


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