Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
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: 2780
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: 2780
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


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
EcoFlow, il Black Friday porta grande ri...
Gli sconti più pesanti del Black ...
Smart #5 BRABUS segna il nuovo record di...
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: 19:10.


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