Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-07-2010, 18:16   #1
seibi
Member
 
Iscritto dal: Oct 2009
Messaggi: 30
[java] nanoTime()

ciao a tutti, implementando un test per la connessione tcp tra due client prendo un timestamp1 all'invio del mex dal client1 e ne prendo unaltro (timestamp2) alla ricezione del mex sul client2 e ne calcolo la differenza per ottenere il tempo impiegato alla trasmissione del pacchetto.

il problema è che su un pc il timestamp è dell'ordine di 10^12 mentre in un'altro è di 10^15 e di conseguenza il risultato della sottrazione mi da un valore non verosimile(qualcosa come 10^4 sec) dove è il problema?

i pc sono sincronizzati in orario al secondo.

grazie anticipatamente
seibi è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2010, 19:13   #2
nalsk
Member
 
L'Avatar di nalsk
 
Iscritto dal: Jun 2009
Messaggi: 38
Non so il tuo problema mi fa pensare ad una discrepanza di versioni del JDK..anche se non ne sono per niente certo. Io avrei controllato la versione dei rispettivi JDK o JRE a seconda di quale usi. Se non dovesse bastare mi arrangerei cambiando a manina l'ordine di grandezza.

EDIT: ok su ho detto una fesseria.. se i due pc sono veramente sincronizzati al secondo (anche stessa data) non dovrebbero esserci differenze in alcun caso!

Ultima modifica di nalsk : 02-07-2010 alle 19:16.
nalsk è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2010, 19:19   #3
seibi
Member
 
Iscritto dal: Oct 2009
Messaggi: 30
tutto sincronizzato....le versioni sono le stesse
seibi è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2010, 19:46   #4
astorcas
Senior Member
 
L'Avatar di astorcas
 
Iscritto dal: Jan 2005
Città: Siena
Messaggi: 1313
credo dipenda dalla risoluzione del timer di sistema
astorcas è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2010, 22:52   #5
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
E' che a nanotime() gli prende a male e restituisce valori negativi per un certo periodo di tempo, quindi finisci per fare
-10^12 - ( -10^15) = 10^3

Non chiedermi perchè fa così però
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 02-07-2010, 23:50   #6
astorcas
Senior Member
 
L'Avatar di astorcas
 
Iscritto dal: Jan 2005
Città: Siena
Messaggi: 1313
Quote:
Originariamente inviato da Tommo Guarda i messaggi
E' che a nanotime() gli prende a male e restituisce valori negativi per un certo periodo di tempo, quindi finisci per fare
-10^12 - ( -10^15) = 10^3

Non chiedermi perchè fa così però
The value returned represents nanoseconds since some fixed but arbitrary time (perhaps in the future, so values may be negative)fonte
ccheccavolovuoldire?

quindi fra due macchine nanotime non serve a na cippa?
astorcas è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 01:03   #7
seibi
Member
 
Iscritto dal: Oct 2009
Messaggi: 30
Quote:
Originariamente inviato da astorcas Guarda i messaggi
The value returned represents nanoseconds since some fixed but arbitrary time (perhaps in the future, so values may be negative)fonte
ccheccavolovuoldire?

quindi fra due macchine nanotime non serve a na cippa?
sai ke forse hai ragione
seibi è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 11:24   #8
astorcas
Senior Member
 
L'Avatar di astorcas
 
Iscritto dal: Jan 2005
Città: Siena
Messaggi: 1313
Quote:
Originariamente inviato da Tommo Guarda i messaggi
-10^12 - ( -10^15) = 10^3
sei sicuro?
astorcas è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 11:39   #9
Tommo
Senior Member
 
L'Avatar di Tommo
 
Iscritto dal: Feb 2006
Messaggi: 1304
Quote:
Originariamente inviato da astorcas Guarda i messaggi
sei sicuro?
MMMMH no

vabè cmq il succo è quello
__________________
*ToMmO*

devlog | twitter
Tommo è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 12:23   #10
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Penso che dovresti usare currentTimeMillis. Ad ogni modo non ho capito come hai fatto a sincronizzare perfettamente gli orari dei due computer.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 15:15   #11
seibi
Member
 
Iscritto dal: Oct 2009
Messaggi: 30
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Penso che dovresti usare currentTimeMillis. Ad ogni modo non ho capito come hai fatto a sincronizzare perfettamente gli orari dei due computer.
li ho semplicemente regolati nell'orologio di win... ci sarà discrepanza di mezzo secondo...cmq io ora per effettuare il test sui tempi di connessione TCP prendo due timeStamp, uno quando il client ha spedito e laltro quando il server ha ricevuto e poi faccio la differenza, è per questo che ho bisogno che i due pc siano sincronizzati...

...secondo voi è piu corretto mettere i timeStamp sulla stessa macchina?? e quindi prima e dopo la spedizione o prima/dopo la ricezione...
seibi è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2010, 15:56   #12
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
La cosa migliore sarebbe calcolare il tempo di andata e ritorno, quindi sì sullo stesso pc, però fai partire il timer, invii il messaggio, arriva la risposta, fermi il timer. Lo fai un po' di volte e fai una media.
In ogni caso, avendo sincronizzato i pc in quel modo non ha senso ricorrere ad una precisione al nanosecondo. Al millisecondo è già fin troppo, anzi dubito che otterrai dei valori significativi in ogni caso con questo metodo.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2010, 15:08   #13
__ZERO_UNO__
Member
 
L'Avatar di __ZERO_UNO__
 
Iscritto dal: Jul 2009
Città: Milano
Messaggi: 270
Puoi usare una istanza (due) della classe Calendar e i relativi metodi, sembra fatta appositamente....
__________________

AMD PII x4 955 BE | Sapphire HD4850 Vapor-X 1 GB | Samsung SpinPoint F1 500GB | Samsung EcoGreen F4 2TB
Gigabyte GA-MA790FXT-UD5P | Fractal Design Define R3 USB3.0 Titanium Grey | CORSAIR 650W CMPSU-650TX
Noctua U12P SE2 | 2 x 2GB Kingston 1333 MHz | Samsung SyncMaster P2450 | Samsung SyncMaster T200
__ZERO_UNO__ è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2010, 17:06   #14
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
nanotime misura intervalli di tempo, precisamente l'intervallo che occorre tra due invocazioni successive dello stesso metodo nanoTime. A differenza di currentTimeMillis il "timer" è inizializzato alla prima invocazione con un valore arbitrario. Così due nanoTime su macchine diverse restituiscono valori assolutamente incomparabili (mentre per currentTimeMillis si tratta sempre di un valore relativo ad una data prefissa rispetto alle impostazioni di sistema).

In ogni caso nanoTime è applicabile al tuo caso perchè il tuo caso è sensatamente gestibile solo se la misurazione avviene su un'unica macchina. Può essere chi invia, chi riceve o una terza macchina (un time server) ma sempre una dev'essere altrimenti la misurazione dipende da fattori che non puoi controllare.

Esegui un nanoTime quando invii la richiesta, ne esegui un'altro quando ricevi la risposta, la differenza tra i due è il tempo trascorso secondo la risoluzione della più precisa funzione di temporizzazione disponibile alla piattaforma (che potrebbe benissimo essere la stessa di currentTimeMillis). E questo rende irrilevante la sincronizzazione.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 05-07-2010, 01:38   #15
seibi
Member
 
Iscritto dal: Oct 2009
Messaggi: 30
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
nanotime misura intervalli di tempo, precisamente l'intervallo che occorre tra due invocazioni successive dello stesso metodo nanoTime. A differenza di currentTimeMillis il "timer" è inizializzato alla prima invocazione con un valore arbitrario. Così due nanoTime su macchine diverse restituiscono valori assolutamente incomparabili (mentre per currentTimeMillis si tratta sempre di un valore relativo ad una data prefissa rispetto alle impostazioni di sistema).

In ogni caso nanoTime è applicabile al tuo caso perchè il tuo caso è sensatamente gestibile solo se la misurazione avviene su un'unica macchina. Può essere chi invia, chi riceve o una terza macchina (un time server) ma sempre una dev'essere altrimenti la misurazione dipende da fattori che non puoi controllare.

Esegui un nanoTime quando invii la richiesta, ne esegui un'altro quando ricevi la risposta, la differenza tra i due è il tempo trascorso secondo la risoluzione della più precisa funzione di temporizzazione disponibile alla piattaforma (che potrebbe benissimo essere la stessa di currentTimeMillis). E questo rende irrilevante la sincronizzazione.
grazie 1000 sei stato chiarissimo...farò come hai detto te con nanoTime
seibi è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Qualcomm potrebbe utilizzare una tecnolo...
Starfield per Nintendo Switch 2 potrebbe...
Un MacBook Pro a -300€, i MacBook Air M4...
Amazon abbassa i prezzi sugli iPhone: sc...
Amazon, ancora sconti sugli smartphone A...
iPhone Air 2 'riciclerà' alcuni c...
Offerta Amazon da non perdere: lo speake...
Nioh 3 debutta alla grande su Steam: pri...
Al centro della Via Lattea ci potrebbe e...
Elon Musk ora guarda alla Luna: SpaceX p...
La Cina ha lanciato nuovamente lo spazio...
Blue Origin potrebbe realizzare il lande...
Artemis II: il prossimo Wet Dress Rehear...
Il nuovo HONOR 600 sta arrivando e avr&a...
La crisi delle memorie non coinvolger&ag...
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: 11:33.


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