Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-03-2013, 10:43   #21
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
problema risolto, il segreto era proprio tale linea

while((ByteRicevuti=Socket->ReceiveBuf(Buf, Size)) > 0);

se dovesse servire a qualcuno

Codice:
void __fastcall TForm1::ServerSocket1ClientRead(TObject *Sender,
      TCustomWinSocket *Socket)
{
  char *Buf;
  String Buffer;
  int  Size;
  int ByteRecived;
  int mioheader=0, mioend=0;

  Size = Socket->ReceiveLength();

// inizio a costruire il mio buffer
  if(Size > 0)
   {
         Buf = new char[Size];
         while( (ByteRecived=Socket->ReceiveBuf(buffer, Size)) > 0 )
        {
           if( strstr(Buf.c_str(), "INIZIODATI," ) mioheader++
           if( strstr(Buf.c_str(), "FINEDATI," ) mioend++
           Buffer+=Buf;
        }
   }

   if( mioheader == 1 && mioend == 1  ) 
   {
	MiaFunzione();
             Buffer="";
   }


}

Ultima modifica di misterx : 14-03-2013 alle 12:27.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 08:21   #22
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
[generico] eventi di Borland Builder

ciao,
avrò letto quasi tutta la rete ma ancora non sono soddisfatto in quanto mi rimangono sempre dei dubbi che non mi permettono di capire sino in fondo se quello che sto facendo ha un senso.

In Borland Builder quando si decide di scrivere un applicativo server, il programmatore ha a disposizione una ricca serie di componenti i quali posseggono metodi (funzioni), proprietà ed eventi.
Una volta implementato un piccolo server, ad esempio, si ha a disposizione l'evento

void __fastcall TForm1::ServerSocket1ClientRead(TObject *Sender,
TCustomWinSocket *Socket)
{
}

che ho già mostrato in altri 3D di cui però non è chiarissimo quante volte viene scatenato.
Supponiamo che un client si connette al server e vuole inviare 1 file da 1 MB; se non erro la dimensione massima di un pacchetto TCP/IP è di 8192 byte quindi, il client deve inviare al server 1048576:8192=128 pacchetti sempre che si abbia la fortuna che i pacchetti siano tutti da 8192 byte.
Se qualcuno che ha avuto a che fare con Borland Builder mi sa dire se l'evento citato sopra viene generato 128 mi farebbe un grandissimo favore. Ho provato ad inserire in quell'evento una variabile contatrice, globale, ed ho notato che inviando un file da qualche centinaio di KB si direbbe che viene generato parecchie volte e si direbbe, tante quanti sono i pacchetti ricevuti dal server: ma è così o c'è dell'altro che non riesco a scovare da nessuna parte?


grazie 1000
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 09:01   #23
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12847
Quote:
Originariamente inviato da misterx Guarda i messaggi
ciao,
avrò letto quasi tutta la rete ma ancora non sono soddisfatto in quanto mi rimangono sempre dei dubbi che non mi permettono di capire sino in fondo se quello che sto facendo ha un senso.

In Borland Builder quando si decide di scrivere un applicativo server, il programmatore ha a disposizione una ricca serie di componenti i quali posseggono metodi (funzioni), proprietà ed eventi.
Una volta implementato un piccolo server, ad esempio, si ha a disposizione l'evento

void __fastcall TForm1::ServerSocket1ClientRead(TObject *Sender,
TCustomWinSocket *Socket)
{
}

che ho già mostrato in altri 3D di cui però non è chiarissimo quante volte viene scatenato.
Supponiamo che un client si connette al server e vuole inviare 1 file da 1 MB; se non erro la dimensione massima di un pacchetto TCP/IP è di 8192 byte quindi, il client deve inviare al server 1048576:8192=128 pacchetti sempre che si abbia la fortuna che i pacchetti siano tutti da 8192 byte.
Se qualcuno che ha avuto a che fare con Borland Builder mi sa dire se l'evento citato sopra viene generato 128 mi farebbe un grandissimo favore. Ho provato ad inserire in quell'evento una variabile contatrice, globale, ed ho notato che inviando un file da qualche centinaio di KB si direbbe che viene generato parecchie volte e si direbbe, tante quanti sono i pacchetti ricevuti dal server: ma è così o c'è dell'altro che non riesco a scovare da nessuna parte?


grazie 1000
Dipende dal frame ethernet e dall'MTU dei router.

Tipicamente Ethernet standard può arrivare fino a 1514 bytes ( con i Jumbo Frame si arriva circa ai 9KB se non erro e con i Super Jambo Frame a 64K).

Tolti i 14 bytes per l'header di Ethernet, rimangono 1500 bytes per IP, ed è tipicamente l'MTU che utilizzano i router.

Leva altri 40 bytes di header di IP e TCP e arrivi a 1460 bytes di dati utili.

Questo significa che nel tuo esempio il trasferimento di un file da 1MB richiederebbe:

1048576/1460 = 719 pacchetti circa

Nota bene: se decidi di leggere da una socket 4K alla volta, i meccanismi di buffering del sistema operativo potrebbero far abbassare il numero di system call necessarie.

Il punto è che stai usando un'api di cui se non ho capito male non si conoscono i dettagli implementativi.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 10:29   #24
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Il punto è che stai usando un'api di cui se non ho capito male non si conoscono i dettagli implementativi.
è esattamente così. Mi sto ostinando ad usare tale componente già pronto solo perchè, essendo il mio progetto piuttosto complesso, tale componente è gia testato e mi fa comodo evitare problemi che di sicuro già esistono da qualche parte.
Per conoscenza, 8192 sono i byte che mi indica il compilatore quando chiamo la Size = Socket->ReceiveLength(); e quando invio da un client pacchetti di una certa dimensione cioè: il mio client casareccio legge da disco attraverso una fgets() ed ogni linea letta viene bufferizzata formando un bufferone che solo alla fine passa alla SendBuf() la quale crea pacchetti da 8192 byte.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 12:55   #25
ESSE-EFFE
Member
 
Iscritto dal: May 2009
Messaggi: 186
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Il punto è che stai usando un'api di cui se non ho capito male non si conoscono i dettagli implementativi.
A dire il vero tra documentazione ufficiale (http://docs.embarcadero.com/products/rad_studio/), libri, portali dedicati, forum, newsgroup e sorgenti VCL di informazioni se ne trovano a quintali.
__________________
ESSE-EFFE.com
Sviluppo software e Web
Creazione loghi - Bergamo
ESSE-EFFE è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 16:16   #26
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da ESSE-EFFE Guarda i messaggi
A dire il vero tra documentazione ufficiale (http://docs.embarcadero.com/products/rad_studio/), libri, portali dedicati, forum, newsgroup e sorgenti VCL di informazioni se ne trovano a quintali.
se mi dici dove spiega quanto chiedo mi faresti un grandissimo favore, io non trovo nulla.

p.s.
questa ti sembra una spiegazione?

http://docwiki.embarcadero.com/Libra....ReceiveLength

Ultima modifica di misterx : 16-03-2013 alle 16:33.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 17:30   #27
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12847
Io consiglierei di partire da qua:

http://docwiki.embarcadero.com/Libra...inSocketStream


Quote:
Originariamente inviato da misterx Guarda i messaggi
se mi dici dove spiega quanto chiedo mi faresti un grandissimo favore, io non trovo nulla.

p.s.
questa ti sembra una spiegazione?

http://docwiki.embarcadero.com/Libra....ReceiveLength
Call ReceiveLength to determine the amount of information to read over the socket connection in response to an asynchronous read notification.

Note: ReceiveLength is not guaranteed to be accurate for streaming socket connections.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 17:54   #28
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
Quote:
Originariamente inviato da WarDuck Guarda i messaggi
Io consiglierei di partire da qua:

http://docwiki.embarcadero.com/Libra...inSocketStream




Call ReceiveLength to determine the amount of information to read over the socket connection in response to an asynchronous read notification.

Note: ReceiveLength is not guaranteed to be accurate for streaming socket connections.
letto grazie 1000, lo trovo però molto lacunoso; molte delle cose che osservo sperimentando non vengono minimamente spiegate e ti vedi costretto a fare miriadi di esperimenti, non che ciò mi turbi però vorrei ottenere alla fine un qualcosa di affidabile che riesco a controllare e non un qualcosa che funzionicchia chissà perchè
Andrà a finire che seguirò alla lettera il tuo consiglio, spostarmi sulle care e vecchi windows API, almeno vedi ciò che accade.

Cerca cerca ho trovato la guida Borland Builder per windows dove si dice che usare le socket in questo ambiente è banale, basta trascinare e settare qualche proprietà e tutto il resto è magia, mah

Se arrivo da qualche parte faccio sapere, almeno il prossimo non diventa matto come lo sto diventando io e ci scommetto che sono vittima di una banalità

grazie ancora per i link
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 16-03-2013, 21:42   #29
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
trovandomi a lavorare col mio programma a livello applicativo, sotto ho TCP(IP che mi da le dovute garanzie, esiste una casistica che spiega a cosa possono essere dovuti eventuali perdite di pacchetti a livello applicativo?

Ho notato che nel piccolo client che ho scritto se aggiungo un ritardo di 20 ms nell'inoltro di pacchetti non ho perdite, però questo è un modo non corretto di operare in quanto mi baso sulla probabilità/fortuna che tutti i pacchetti arrivano entro 20 ms. Se dovessi avere un ritardo maggiore per una qualche ragione addio
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2013, 09:59   #30
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3736
edit

Ultima modifica di misterx : 18-03-2013 alle 09:15.
misterx è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Nuovo storico lancio per il razzo spazia...
Elgato Embrace: una sedia ergonomica pro...
Brad Pitt torna in pista: F1 – Il Film a...
Hitachi Vantara annuncia la sua AI Facto...
Brembo passa all'alluminio riciclato al ...
HONOR pronta a sfidare gli iPad Pro con ...
OpenAI esce allo scoperto: confermati i ...
In arrivo altri due prodotti da Apple en...
Il tool per aggiornare da Windows 10 a W...
Rishi Sunak entra in Microsoft e Anthrop...
Porsche in poche ore chiude la formazion...
iPhone 17 disponibili su Amazon al prezz...
La Ferrari Elettrica non è la cau...
Ricarica da record: Zeekr supera i 1.300...
Un 'capezzolo' con feedback aptico al po...
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: 06:08.


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