Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Attenti a Poco F7: può essere il best buy del 2025. Recensione
Attenti a Poco F7: può essere il best buy del 2025. Recensione
Poco F7 5G, smartphone che punta molto sulle prestazioni grazie al processore Snapdragon 8s Gen 4 e a un display AMOLED da ben 6,83 pollici. La casa cinese mantiene la tradizione della serie F offrendo specifiche tecniche di alto livello a un prezzo competitivo, con una batteria generosissima da 6500 mAh e ricarica rapida a 90W che possono fare la differenza per gli utenti più esigenti.
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale
Abbiamo provato per molti giorni il nuovo Z Fold7 di Samsung, un prodotto davvero interessante e costruito nei minimi dettagli. Rispetto al predecessore, cambiano parecchie cose, facendo un salto generazionale importante. Sarà lui il pieghevole di riferimento? Ecco la nostra recensione completa.
The Edge of Fate è Destiny 2.5. E questo è un problema
The Edge of Fate è Destiny 2.5. E questo è un problema
Bungie riesce a costruire una delle campagne più coinvolgenti della serie e introduce cambiamenti profondi al sistema di gioco, tra nuove stat e tier dell’equipaggiamento. Ma con risorse limitate e scelte discutibili, il vero salto evolutivo resta solo un’occasione mancata
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-01-2010, 03:41   #1
DooM1
Senior Member
 
L'Avatar di DooM1
 
Iscritto dal: Jul 2002
Città: Cagliari
Messaggi: 13495
[VB.net] socket.Accept - come usarlo

Ciao, tempo fa programmai una chat in VB6, usando il WinSock (controllo OCX). Ci avevo messo un po' ma c'ero riuscito, ed avevo imparato tante cosettine.
Ora voglio rifare tutto da capo con VB.net (ora sto usando Visual Basic 2008 express edition), ma ho dei problemi con la classe Socket.

Diciamo che ho fatto tutto ma ho problemi con la ricezione di dati o di connessioni.

In pratica facciamo che metto la chat in listening, quindi uso il metodo Listen() della classe Socket.
Dopodichè, in VB6 usavo il metodo Accept() "dentro" l'evento ConnectionRequest. Ma ora in VB.net non ho nessun evento.

Non capisco proprio come faccio a eseguire Accept() nel momento in cui arriva una richiesta di connessione (se non ho a disposizione gli eventi).

Io ho ipotizzato 2 alternative:

1) fare il polling con un timer per determinare quando è richiesta una connessione: ma questa soluzione non mi piace affatto, perchè non voglio che se la chat rimane disconnessa per lungo tempo rimanga cercando e impegnando risorse (anche se poca roba), e poi la connessione non sarebbe immediata perchè non è sincrona (non sò se mi sono spiegato)
2) intercettare in qualche modo l'evento... se fa... e se il socket lo permette (ma da quello che ho capito non ha nessun gestore eventi e non capisco perchè).

In effetti ci sarebbe un altra ipotesi, ossia di creare l'evento ex-novo (se già non esiste da intercettare).
Ma in tutti gli esempi che ho visto per creare eventi, c'è l'utilizzo di un ciclo infinito in background o di un timer.

Insomma non se ne esce da timer o cicli infiniti. Ma gli eventi funzionano tutti a così (timer o loop infiniti)?

Mi illuminate per favore?
Grazie.
__________________
MoBo:Asus Prime x470-Pro*CPU:AMD Ryzen 5700x*RAM:Kingston FURY KF432C16RB2K2/16*Sk.Vid:Asus DUAL-RX580-O8G*Ali:Enermax Revolution87+ 550W*Storage:Samsung 970 Evo Plus 1TB + Samsung 860 Evo 1TB*Mons:Dell 2209WAf + LG 24EA53VQ
DooM1 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 09:49   #2
ybla82
Junior Member
 
Iscritto dal: May 2006
Messaggi: 23
Il funzionamento di accept è particolare: in pratica l'esecuzione del thread rimane bloccata sulla funzione accept fino a quando non riceve una richiesta.

Detto questo è essenziale mettere la funzione in un thread diverso da quello principale del processo, altrimenti l'applicazione si bloccherebbe completamente.

Un sistema di comunicazione TCP è abbastanza comune, e su internet ci siano molti esempi. Io ne ho trovati in C#, onestamente non ho mai cercato per il VB.NET.
ybla82 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 15:13   #3
DooM1
Senior Member
 
L'Avatar di DooM1
 
Iscritto dal: Jul 2002
Città: Cagliari
Messaggi: 13495
Quote:
Originariamente inviato da ybla82 Guarda i messaggi
Il funzionamento di accept è particolare: in pratica l'esecuzione del thread rimane bloccata sulla funzione accept fino a quando non riceve una richiesta.

Detto questo è essenziale mettere la funzione in un thread diverso da quello principale del processo, altrimenti l'applicazione si bloccherebbe completamente.

Un sistema di comunicazione TCP è abbastanza comune, e su internet ci siano molti esempi. Io ne ho trovati in C#, onestamente non ho mai cercato per il VB.NET.
Ok mi hai dato l'ispirazione, credo di avere risolto
Grazie

In pratica imposto a True il flag Blocking (che dovrebbe esserlo già ma mi pare che se non lo faccio non funziona), poi faccio Bind, poi Listen, e poi in un thread a parte uso Accept, e dopo tutto il codice per accettare che viene eseguito solo quando arriva una richiesta, perchè fino ad allora rimane bloccato su accept.

Funziona grazie di nuovo
__________________
MoBo:Asus Prime x470-Pro*CPU:AMD Ryzen 5700x*RAM:Kingston FURY KF432C16RB2K2/16*Sk.Vid:Asus DUAL-RX580-O8G*Ali:Enermax Revolution87+ 550W*Storage:Samsung 970 Evo Plus 1TB + Samsung 860 Evo 1TB*Mons:Dell 2209WAf + LG 24EA53VQ
DooM1 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 15:23   #4
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Quote:
Originariamente inviato da ybla82 Guarda i messaggi
Il funzionamento di accept è particolare: in pratica l'esecuzione del thread rimane bloccata sulla funzione accept fino a quando non riceve una richiesta.

Detto questo è essenziale mettere la funzione in un thread diverso da quello principale del processo, altrimenti l'applicazione si bloccherebbe completamente.

Un sistema di comunicazione TCP è abbastanza comune, e su internet ci siano molti esempi. Io ne ho trovati in C#, onestamente non ho mai cercato per il VB.NET.
Solitamente, su un server multithread, è quello principale a restare in accept per poi delegare il lavoro di risposta ad altri thread (istanziati al volo o recuperati da un pool)una volta ricevuto il socket.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 15:35   #5
DooM1
Senior Member
 
L'Avatar di DooM1
 
Iscritto dal: Jul 2002
Città: Cagliari
Messaggi: 13495
Quote:
Originariamente inviato da nuovoUtente86 Guarda i messaggi
Solitamente, su un server multithread, è quello principale a restare in accept per poi delegare il lavoro di risposta ad altri thread (istanziati al volo o recuperati da un pool)una volta ricevuto il socket.
Ma se faccio così si blocca tutto il form, tutti i comandi ecc. Come fare?
__________________
MoBo:Asus Prime x470-Pro*CPU:AMD Ryzen 5700x*RAM:Kingston FURY KF432C16RB2K2/16*Sk.Vid:Asus DUAL-RX580-O8G*Ali:Enermax Revolution87+ 550W*Storage:Samsung 970 Evo Plus 1TB + Samsung 860 Evo 1TB*Mons:Dell 2209WAf + LG 24EA53VQ
DooM1 è offline   Rispondi citando il messaggio o parte di esso
Old 07-01-2010, 15:41   #6
nuovoUtente86
Senior Member
 
Iscritto dal: Mar 2007
Messaggi: 7863
Quote:
Originariamente inviato da DooM1 Guarda i messaggi
Ma se faccio così si blocca tutto il form, tutti i comandi ecc. Come fare?
dipende dal com' è strutturata l' applicazione: io ho parlato in generale del modulo server all' interno di un' architettura client-server, non so se tu magari lavori in p2p.
nuovoUtente86 è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 08:14   #7
ybla82
Junior Member
 
Iscritto dal: May 2006
Messaggi: 23
Se stai facendo un'applicazione client, quindi con form, pulsanti ed altro tanto per intenderci, l'accept mettilo in un thread secondario, altrimenti come hai detto giustamente si blocca tutto.

Se stai progettando un server, ma non mi sembra, l'accept deve essere nel thread principale.


Poi pe ril resto il succo è sempre lo stesso: sul metodo accept l'esecuzione si blocca fino alla ricezione di un messaggio. questa è la cosa essenziale
ybla82 è offline   Rispondi citando il messaggio o parte di esso
Old 08-01-2010, 13:38   #8
DooM1
Senior Member
 
L'Avatar di DooM1
 
Iscritto dal: Jul 2002
Città: Cagliari
Messaggi: 13495
Quote:
Originariamente inviato da ybla82 Guarda i messaggi
Se stai facendo un'applicazione client, quindi con form, pulsanti ed altro tanto per intenderci, l'accept mettilo in un thread secondario, altrimenti come hai detto giustamente si blocca tutto.

Se stai progettando un server, ma non mi sembra, l'accept deve essere nel thread principale.


Poi pe ril resto il succo è sempre lo stesso: sul metodo accept l'esecuzione si blocca fino alla ricezione di un messaggio. questa è la cosa essenziale
Aah ecco ora ho capito meglio ... si, effettivamente è un client solo che può in alternativa accettare la connessione.
Grazie a tutti per l'aiuto

Più avanti vorrei programmare un serverino per poter connettere più chat contemporaneamente (avevo già fatto una bozza in VB6 ma era decisamente da rifare).
Per questo vedrò di accettare le connessioni con il thread principale.
Poi se ho capito bene, programmerò un pannellino di controllo che verrà controllato da un altro thread.
__________________
MoBo:Asus Prime x470-Pro*CPU:AMD Ryzen 5700x*RAM:Kingston FURY KF432C16RB2K2/16*Sk.Vid:Asus DUAL-RX580-O8G*Ali:Enermax Revolution87+ 550W*Storage:Samsung 970 Evo Plus 1TB + Samsung 860 Evo 1TB*Mons:Dell 2209WAf + LG 24EA53VQ
DooM1 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Attenti a Poco F7: può essere il best buy del 2025. Recensione Attenti a Poco F7: può essere il best buy...
Recensione Samsung Galaxy Z Fold7: un grande salto generazionale Recensione Samsung Galaxy Z Fold7: un grande sal...
The Edge of Fate è Destiny 2.5. E questo è un problema The Edge of Fate è Destiny 2.5. E questo ...
Ryzen Threadripper 9980X e 9970X alla prova: AMD Zen 5 al massimo livello Ryzen Threadripper 9980X e 9970X alla prova: AMD...
Acer TravelMate P4 14: tanta sostanza per l'utente aziendale Acer TravelMate P4 14: tanta sostanza per l'uten...
TSMC produrrà a 2 nm anche in Ari...
Tesla vuole Musk a tutti i costi: propos...
Spotify aumenta i prezzi: da 10,99 a 11,...
Prezzi folli su AliExpress con Choice Da...
IA ed etica: Fastweb+Vodafone fra le pri...
Pannelli solari nuovi o riciclati? Quest...
Instagram cambia le regole per i Live: n...
Windows 11 SE addio: Microsoft stabilisc...
Kali Linux più facile su macOS gr...
È la fine per le antenne 5G? Al l...
WhatsApp, una taglia da 1 milione di dol...
Sembrava spacciato, poi una bici elettri...
Apple Watch Series 1 diventa obsoleto: a...
ho. Mobile, upgrade a 250 GB senza sovra...
Reddit non avrà post a pagamento,...
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: 03:11.


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