Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 30-10-2011, 20:34   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
[C/C++] rivolto a chi conosce il multithread e borland c++ builder

ho implementato due thread nel mio progetto e ho incluso anche il componente ServerSocket.

So che i due thread vengono eseguiti in parallelo, ma non è questo il mio problema ma un altro: ho settato nel componente ServerSocket l'evento OnClientRead in quanto desidero che il server risponda quando il client invia qualche messaggio al server e mi chiedevo: la risposta a tale evento assieme all'esecuzione dei due thread come viene vista al fine dell'esecuzione dell'intero processo?

Può esistere che i due thread e l'esecuzione del codice incluso nell'evento sia come eseguire tre thread oppure quando si esegue l'evento i due thread vengono messi in wait?

Sarebbe meglio scrivere un terzo thread per soddisfare i messaggi dei client oppure già così com'è fatto è performante?

Spero di essere stato chiaro anche se ho qualche dubbio.

Ultima modifica di misterx : 31-10-2011 alle 11:41.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2011, 13:49   #2
starfred
Senior Member
 
Iscritto dal: Jul 2011
Messaggi: 381
Non c'ho capito molto . Prova ad esser più chiaro oppure riporta il codice o preferibilmente pseudocodice
__________________
Concluso positivamente con: Kamzata, Ducati82, Arus, TheLastRemnant, ghost driver, alexbull1, DanieleRC5, XatiX
starfred è offline   Rispondi citando il messaggio o parte di esso
Old 31-10-2011, 17:56   #3
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Codice:
#include <......>
int tempo[255];

void __fastcall TForm1::Button1Click(TObject *Sender)
{
        produttore = CreateThread(NULL,0,ThreadProduttore,NULL,0,&ID1);
        scrittore = CreateThread(NULL,0,ThreadScrittore,NULL,0,&ID2);
}


DWORD WINAPI ThreadProduttore( LPVOID lpParameter)
{
        
        for(int pp=0; pp < 255;pp++) tempo[pp]=xx;
}


DWORD WINAPI ThreadScrittore( LPVOID lpParameter )
{
                for(int pp=0; pp < 255;pp++) 
                Label1->Caption = tempo[pp];
}
l'esempio è banale, il primo thread riempie ed il secondo visualizza. NOn ho usato semafori in quanto non è necessario ai fini del mio dubbio.

ora aggiungo il seguente evento

Codice:
void __fastcall TForm1::ServerSocket1ClientRead(TObject *Sender,
      TCustomWinSocket *Socket)
{
        int tmp;
        String ClientRequest = Socket->ReceiveText();



                if(ClientRequest.SubString(1,2) == "CA"){       /* carica un part-program sul CN */
                        tmp = ClientRequest.Length()-3;
                        CaricaPartProgram( ClientRequest.SubString(3, tmp ));

                        Memo1->Lines->Add("Carico programma");
                }

        Memo1->Lines->Add("Messaggio generico");
}
i due thread sopra esposti vengono eseguiti in base a come windows li schedula.
Come viene eseguito invece l'evento ServerSocket1ClientRead() ?
Viene trattato come se fosse un thread oppure, quando si passa ad eseguirlo gli altri due thread vongono messi in wait sono a quando l'evento è stato soddisfatto?

Quello che mi preoccupa è la perdita del parallelismo di due thread ad opera dell'evento.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2011, 10:09   #4
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
produttore = CreateThread(NULL,0,ThreadProduttore,NULL,0,&ID1);
scrittore = CreateThread(NULL,0,ThreadScrittore,NULL,0,&ID2);
Perchè non usi la classe TThread inclusa nella VCL?

Quote:
Originariamente inviato da misterx Guarda i messaggi
DWORD WINAPI ThreadScrittore( LPVOID lpParameter )
{
for(int pp=0; pp < 255;pp++)
Label1->Caption = tempo[pp];
}
Questo non puoi farlo. Non puoi accedere alla UI da un thread senza sincronizzare le cose.

Quote:
Originariamente inviato da misterx Guarda i messaggi
Come viene eseguito invece l'evento ServerSocket1ClientRead() ?
Viene trattato come se fosse un thread oppure, quando si passa ad eseguirlo gli altri due thread vongono messi in wait sono a quando l'evento è stato soddisfatto?
I thread che crei girano in parallelo anche al thread che gestisce la UI (che non crei tu manualmente, ma c'è). Quindi il codice dell'evento non blocca i thread. Ti bastano poche righe di codice per verificarlo tu stesso.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 02-11-2011, 20:47   #5
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
Perchè non usi la classe TThread inclusa nella VCL?



Questo non puoi farlo. Non puoi accedere alla UI da un thread senza sincronizzare le cose.



I thread che crei girano in parallelo anche al thread che gestisce la UI (che non crei tu manualmente, ma c'è). Quindi il codice dell'evento non blocca i thread. Ti bastano poche righe di codice per verificarlo tu stesso.


due domande: cosa intendi per UI?
Per verificarlo da solo intendi che sarebbe sufficiente inserire qualche contatore nei due thread e nell'evento?

ciao
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2011, 09:53   #6
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da misterx Guarda i messaggi
cosa intendi per UI?
User Interface. In questo caso forse era meglio parlare di GUI, però il senso penso si capisca.

Quote:
Originariamente inviato da misterx Guarda i messaggi
Per verificarlo da solo intendi che sarebbe sufficiente inserire qualche contatore nei due thread e nell'evento?
Potrebbe essere un modo, sì.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 03-11-2011, 16:33   #7
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
grazie


quindi è come se avessi implementato tre thread di cui uno è gratis
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Ecovacs presenta la gamma 2026: paviment...
Efficienza energetica fino a 2.000 volte...
Lenovo 360: il programma di canale dell'...
Appena 10.000 qubit per rompere la critt...
Analisi dei transistor durante il funzio...
Attacco informatico a Booking.com: espos...
A quattro mesi dal divieto dei social ne...
NVIDIA GeForce RTX 5060 e 5060 Ti: in ar...
Rebellions, Arm e SK Telecom, nuova alle...
Modernizzazione delle app: Red Hat OpenS...
Nel mirino di Google c'è il back ...
PRAGMATA in bundle con GeForce RTX 5000:...
Le novità MOVA per il 2026: robot e impi...
Windows, stop all'attivazione telefonica...
ASUS porta la serie TUF nel formato Mini...
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: 00:14.


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