Was ist genauer: Thread.sleep() oder meine Variante?

Status
Nicht offen für weitere Antworten.

JPKI

Top Contributor
Schönen Tag auch.

Folgendes: Ich möchte einen Timer schreiben, der die Zeit vom Sytemstart bis zum Herunterfahren misst und in
einem Fenster mit sechs digitalen Ziffern darstellt. Dazu sollte auch die Zeitmessung sehr genau sein.

Jetzt meine Frage: Welcher der beiden von mir in Betracht gezogenen Methoden misst genauer?

Methode 1:

Ich lasse mit zu Beginn des Threads die aktuelle Systemzeit mittels System.getCurrentTimeMillis() geben
und ziehe diese dann bei jedem Hochzählen von der aktuellen Systemzeit ab. Dann habe ich die Millisekunden,
sie seit Beginn vergangen sind, rechne diese so um, dass ich sie auf sechs Digitalziffern verteilen kann und gebe
sie in einem int-Array aus:
Code:
public class TimeManager {

  private long systemTime, currentTime;
  private int hours, minutes, seconds;

  public TimeManager() {

   systemTime = System.currentTimeMillis();

   hours = 0;
   minutes = 0;
   seconds = 0;
 }

  public void countUp() { //diese Methode wird von einem externen Thread jede Sekunde aufgerufen

   currentTime = System.currentTimeMillis();
   long difference = (currentTime-systemTime)/1000;

   hours = (int)difference/3600;
   minutes = (int)(difference%3600)/60;
   seconds = (int)(difference%3600)%60;
 }

  public void start() {

   systemTime = System.currentTimeMillis();
 }

  public void reset() {

   hours = 0;
   minutes = 0;
   seconds = 0;
 }

  public int[] getTimeValues() {

   return new int[]{ (int)Math.floor(hours/10),
                     (int)hours%10,
                     (int)Math.floor(minutes/10),
                     (int)minutes%10,
                     (int)Math.floor(seconds/10),
                     (int)seconds%10 };
 }
}

Methode 2:

Ich definiere eine Variable int i = 0, zähle sie in einer while-Schleife immer um eins hoch und lasse den Thread mittels Thread.sleep() 1000 Millisekunden schlafen. Der Rest würde dann wie oben gehen.
 

schalentier

Gesperrter Benutzer
Beides ist ungenau. Der Java Timer (System.currentTimeMillis()) misst nur ca. 50-100ms.. Aber Variante 1 ist definitiv besser, das andre ist noch ungenauer, da auch noch paar Millisekunden fuer die while Schleife draufgehen.

Gibt irgendwo son Native-Interface fuer den HighPrecisionTimer deiner CPU, glaub ich. Das ist dann sicherlich genauer als die 50-100ms...
 

Wildcard

Top Contributor
schalentier hat gesagt.:
Beides ist ungenau. Der Java Timer (System.currentTimeMillis()) misst nur ca. 50-100ms.
Das ist ein reines Windows-Problem da die bereitgestellte API verbugt ist.
System.nanoTime verwendet daher eine andere Lib der Win-API und ist wesentlich genauer.
 

Wildcard

Top Contributor
Windows typisch ist das aber weiterhin verbuggt.
Soweit ich gelesen habe kann sehr häufiges und schnelles Aufrufen dieser Methode die Systemzeit verstellen :autsch:
 

JPKI

Top Contributor
Wildcard hat gesagt.:
Soweit ich gelesen habe kann sehr häufiges und schnelles Aufrufen dieser Methode die Systemzeit verstellen :autsch:
Hä? Wo haste das denn gelesen?
Liefert nanoTime() auch ein long, das man dann wie oben genannt subtrahieren kann? Oder liefert's was anderes?
 

JPKI

Top Contributor
War grad zu faul um nachzuschauen...
@Wildcard: In dem Bericht steht, dass der Bericht schon gefixt wurde.
 

JPKI

Top Contributor
Die Kommentare hab ich net gelesen ;-)
Eine Frage noch: Wie genau/ungenau ist denn nanoTime() jetzt ungefähr?
Und ab welcher Distribution gibt's nanoTime() denn?
 

Wildcard

Top Contributor
Dann empfehle ich dir für WinXP googeln zum Thema QueryPerformanceCounter.
Soetwas wie Linux 9.1 gibt es nicht :autsch: :autsch: :autsch:
 

sparrow

Top Contributor
JPKI hat gesagt.:
Wildcard hat gesagt.:
Plattformabhängig. Je nach dem was das OS hergibt.
Für Windows XP und Linux 9.1 würd ich's gern ungefähr wissen.

Öhm.... Also unter Linux 2.6.18 gehts sehr gut und genau. Und da springt auch keine Systemzeit. Uner Windows springt die Systemzeit bei dem zu häufigen Aufruf von Thread.sleep() mit sehr geringen Werten.
Ich hätte aber gerne den Sourcecode von Linux 9.1. Damit könnte ich viel Geld machen.
SCNR


Gruß
Sparrow
 

Wildcard

Top Contributor
Linux ist ein Kernel. Aktuelle Version 2.6.20.7.
Das was man gerne als Linux bezeichnet (das Betriebssystem) ist mehr als ein Kernel, man spricht daher häufig von GNU/Linux.
Weiterhin gibt es Distributionen, Suse, Ubuntu, RedHat, Gentoo,...
Distributionen liefern einen in bestimmter Weise vorkonfigurierten Kernel + Tools und Anwednungen aus dem GNU Fundus.
Diese folgen einer eigenen, von Linux unabhängien Versionierung.
 

JPKI

Top Contributor
Linux 2.6.18... meinte ich doch. Bin noch Linux-Einsteiger, deshalb kenn ich mich mit den Versionen noch nicht so aus. Bitte vielmals um Entschuldigung :wink: .
 

Tobias

Top Contributor
Meine Glaskugel sagt, JPKI meinte SuSe 9.1. Da JPKI den Unterschied wohl nicht kennt, die Erläuterung: SuSe ist eine Distribution, die den Linux-Kernel (da ist Version 2.6 meines Wissens gerade aktuell - bin aber kein Linux-Nutzer, kann also auch voll daneben liegen) und verschiedene Programme für diesen Kernel zusammenfasst. Da es viele Distributionen gibt, ist eine Angabe wie "Linux 9.1" Unsinn, da kein Kernel mit dieser Versionsnummer existiert, und ohne weitere Informationen die Distribution nur geraten werden kann (in Deutschland ist SuSe einfach am weitesten verbreitet, deshalb mein Tipp).

Alle Klarheiten beseitigt?

mpG
Tobias

Edit: Warum zum Teufel übersehe ich eigentlich immer die zweite Seite?
 

sparrow

Top Contributor
JPKI hat gesagt.:
Tobias hat aber Recht. Nutze SuSe 9.1.

Dann wird es Zeit für ein Update ;)
Aktuell ist openSUSE 10.2, SuSE 9.1 ist über 3 Jahre alt. Für eine Suse ist das schon übers Greisenalter hinaus ;)

Unter Linux funktionieren die Timer-Funktionen wirklich ziemlich präzise, immerhin reicht es um die Frames bei einem Spiel zu steuern. Unter Windows kann ich das nicht beurteilen.

System.nanoTime() gibt bei mir hier unter anderem folde Werte:

4263274645000
4263274657000

Die letzten 3 Stellen sind bei mir immer null, dass heisst die kleinste Differenz währen: 1000 Nanos, oder 1 Mikrosekunde, oder 0,001 Millisekunden.

Ob man allerdings so einfach die Auflösung eines Timers bestimmen kann weiss ich nicht.

Das System:

Code:
sparrow@pluto:~$ uname -a
Linux pluto 2.6.17-11-generic #2 SMP Tue Mar 13 23:32:38 UTC 2007 i686 GNU/Linux
sparrow@pluto:~$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:    Ubuntu 6.10
Release:        6.10
Codename:       edgy


Gruß
Sparrow
 

sparrow

Top Contributor
Wildcard hat gesagt.:
sparrow hat gesagt.:
Ob man allerdings so einfach die Auflösung eines Timers bestimmen kann weiss ich nicht.
Die Auflösung schon, die Genauigkeit leider nicht.

Kannst du das mal nöher ausführen? Interessiert mich wirklich.
Wie soll man denn die Genauigkeit eines Timers messen.
Mit der Stopuhr daneben setzen?
*überleg*
Das ist eine völlig ernst gemeinte Frage.
 

Wildcard

Top Contributor
sparrow hat gesagt.:
Wie soll man denn die Genauigkeit eines Timers messen.
Meines Wissens basieren die meisten libs zur Performance Messung (also Funktionen wie nanoTime) auf dem CPU Takt, was besonders bei dynamischen Taktraten (Centrino zB) zu Ungenauigkeiten führen kann.
Wie man es nun sinnvoll misst kann ich dir leider nicht beantworten, aber es ist vermutlich nicht trivial.
 

sparrow

Top Contributor
Wildcard hat gesagt.:
Schmeiß einfach KDE runter und mach zB FluxBox drauf, dann packt er das.

Nicht unbedingt.
YaST braucht seid 10.2 mehr Speicher meider Installation als vorher, oder eine, bereits vor der Installation, eingerichtete Swap-Partition.

Ansonsten haste Recht.


Aber das mit dem Timer interessiert mich, ich lern mal eben Wikipedia auswendig.
 

Fatal Error

Bekanntes Mitglied
hehe beryl :D
kann nicht mehr ohne meine wabbelden fenster leben^^
viel besser als alles unter vista...


aja hast scho das neue 2.0? wo man die fenster gruppiern und tabben kann?
 

sparrow

Top Contributor
Sicherlich das "durchzappen" der Fenster nach und nach.
Meist ausgelöst durch ALT + TAB.

Das besondere bei Beryl/Compiz ist dabei, dass alle Fenster mit Inhalt angezeigt werden und nicht nur die Icons.
 

JPKI

Top Contributor
Wildcard hat gesagt.:
Ich muss mal den guten Mark fragen ob ich Provision für die ganze Werbung kriege :D
Die Provision teilen wir uns aber, denn immerhin haben unseren Dialog bestimmt sehr viele Gäste gelesen, die jetzt auch umsteigen :wink: :bae: .

@Wildcard: Geiler Desktop! Schick mal Link und Tipp mal Systemmindestanforderungen ab (bitte) ;-) .
 

Wildcard

Top Contributor
Link zu was?
Das ist der 3D Desktop Beryl.
Bei mir mit Ubuntu Edgy Eft und Gnome als Window Manager.
berylism.png

beryl.jpg


Die Systemanforderungen...
So ca. 500Mhz 512MB Ram und eine 3D fähige Karte (integrierte Intel Karte reicht völlig).
 

JPKI

Top Contributor
Hm. Würde die Geschwindigkeit sehr darunter leiden, wenn man es auf einem 700 MHz-System mit 128 MB RAM installieren würde?
 

Wildcard

Top Contributor
JPKI hat gesagt.:
Hm. Würde die Geschwindigkeit sehr darunter leiden, wenn man es auf einem 700 MHz-System mit 128 MB RAM installieren würde?
Ich vergas... dein 'Entwicklungsrechner' :roll:
Vergiss es, mit so einer Gurke darf man nicht mitspielen, da läuft gar nichts mehr drauf.
Du hast doch auch einen halbwegs normalen Rechner, mach's doch da rauf.
 

Ariol

Top Contributor
jop, aber ich hab mir mal den leistungs-verbrauch von beryl angesehen:

Das verbraucht kaum etwas...weder viel ram, noch viel cpu, weil das meiste über die Graka läuft.

Und mit FluxBox sollte es doch auch laufen...
 

JPKI

Top Contributor
gute Graka: Für so ne Mühle hört sich ATI Radeon Irgendwas hohes mit 128 MB doch Recht gut an, oder ;-) ?
 

Wildcard

Top Contributor
Ariol hat gesagt.:
Das verbraucht kaum etwas...weder viel ram, noch viel cpu, weil das meiste über die Graka läuft.
Richtig, das Teil ist schon extrem sparsam, aber bei 128MB geht's wirklich um jedes MB. Beryl selbst wird wohl sogar laufen, aber man will ja auch irgendwas auf seinem schönen neuen Desktop anzeigen.
 

Ariol

Top Contributor
leider ist die Unterstützung von Radeon-Karten nicht sehr gut.

Wenn du ein Ubuntu benutzt (oder in deinem Fall besser Fluxbuntu http://fluxbuntu.org/ ) kann ich dir envy empfehlen.

Das installiert dir deinen Graka-Treiber automatisch.
Es sollte auch mit anderen Distros laufen.

Unter http://www.ubuntuusers.de gibt es auch gute wikis zu XGL und Graka-Installationen ;)
 

Wildcard

Top Contributor
Ist übrigens genau die richtige Zeit zum Umsteigen, ab heute ist Ubuntu 7.04 Feisty Fawn final und wartet mit dem neusten Kernel und einem Import Wizard für Windows und Linux Installationen auf. :wink:
Vorsicht, die Server sind zur Zeit völlig überlastet....
 

JPKI

Top Contributor
Heut abend werd ich's mir wohl sowieso nicht mehr runterladen.
Eventuell morgen oder am Wochenende wenn ich Zeit hab.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Class[] genauer spezifizieren Allgemeine Java-Themen 5
K Genauer Speicherbedarf für ein Objekt ? Allgemeine Java-Themen 7
R 11 GB File lesen ohne zu extrahieren Filedaten Bereich für Bereich adressieren dann mit Multi-Thread id die DB importieren Allgemeine Java-Themen 3
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
smarterToby Wie stoppe ich diesen Thread Allgemeine Java-Themen 4
A Thread.sleep Problem Allgemeine Java-Themen 2
J Thread started nur einmal Allgemeine Java-Themen 19
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand Logfile pro User / Thread Allgemeine Java-Themen 7
OnDemand Thread / Service abbrechen Allgemeine Java-Themen 3
Thallius Ist meine static Helper Class Thread save? Allgemeine Java-Themen 9
P Swing Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: npoints > xpoints.length || npoints > ypoints.length Allgemeine Java-Themen 5
B Thread.sleep() in EJB Container wie lösen? Allgemeine Java-Themen 11
S Ist das Neuzuweisen von Feldern atomic und damit Thread-Safe? Allgemeine Java-Themen 2
S Exception in thread "main" java.lang.NullPointerException at FamilienApp.main(FamilienApp.java:15) Allgemeine Java-Themen 1
J Einen Thread in einer Schleife Allgemeine Java-Themen 2
E HILFE !! Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/io/FileUtils Allgemeine Java-Themen 4
Flynn Thread-Problem... Allgemeine Java-Themen 2
G Thread-Programmierung Allgemeine Java-Themen 5
S Datei wird nicht gefunden Thread.currentThread().getContextClassLoader().getResourceAsStream() Allgemeine Java-Themen 1
G Beendet sich der Thread selbst?! Allgemeine Java-Themen 3
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
S Thread beenden Allgemeine Java-Themen 9
M Array aus Thread Objekten erstellen Allgemeine Java-Themen 2
Aruetiise Swing JOptionPane ohne denn Thread zu pausieren Allgemeine Java-Themen 1
M Nanosekunden-Pause innerhalb einen Thread-Loops Allgemeine Java-Themen 3
E Thread Exception Allgemeine Java-Themen 6
javaerd Binomialkoeffizient ausrechnen, Exception in thread "main" java.lang.StackOverflowError Allgemeine Java-Themen 6
T Merkwürdiges Thread-Verhalten Allgemeine Java-Themen 6
K Thread Problem Allgemeine Java-Themen 6
W Thread sleep 30 sekunden - wenn keine Antwort bis dahin neu senden Allgemeine Java-Themen 2
H Thread bleibt stehen bei jar in jar Allgemeine Java-Themen 1
J Threads HTTP Request (Thread) dauert lange - in Android Allgemeine Java-Themen 3
F CPU Last eines Thread ausfindig machen Allgemeine Java-Themen 0
V Compiler-Fehler Exception in thread "AWT-EventQueue-0" java.lang.IndexOutOfBoundsException: Index: 125, Size: 125 Allgemeine Java-Themen 11
Tausendsassa Threads Einen Thread sich selbst schließen lassen Allgemeine Java-Themen 17
P Threads BufferedImage, Thread Concurrency Allgemeine Java-Themen 1
M Klasse in separaten Thread ausführen.Wie genau? Allgemeine Java-Themen 2
llabusch Thread blockiert Dialog Allgemeine Java-Themen 1
J Thread wait() Allgemeine Java-Themen 2
V Thread.sleep und InterruptedException? Allgemeine Java-Themen 1
G Thread nicht von GC zerstört Allgemeine Java-Themen 6
J Wie erschaffe ich einen sicheren Datenaustausch zwischen Thread und Nicht-Threads Allgemeine Java-Themen 8
Sogomn Thread blocken bis Taste gedrückt Allgemeine Java-Themen 5
T Starten vom Thread Allgemeine Java-Themen 3
T Wait/Notify() bei Thread Allgemeine Java-Themen 6
J Exception in thread "main" java.lang.NoClassDefFoundError Allgemeine Java-Themen 4
M Exception in thread "AWT-EventQueue-0" Allgemeine Java-Themen 6
Q Thread wacht nicht auf Allgemeine Java-Themen 7
T Fragen zum Thread-Thema Allgemeine Java-Themen 4
T Threads Input/Output im Thread - Datei ohne Inhalt Allgemeine Java-Themen 1
T Fragen zum Thread-Thema Allgemeine Java-Themen 9
C Threads Variablen in einem Thread Aktualisieren Allgemeine Java-Themen 17
U Thread beenden Allgemeine Java-Themen 3
W Threads Mit Thread und Runtime externe Programme öffnen Allgemeine Java-Themen 0
N Thread interrupt Status debuggen Allgemeine Java-Themen 6
A Thread: Code paralell ausführen in mehreren Instanzen Allgemeine Java-Themen 1
E Threads linkedlist/multi-thread problem Allgemeine Java-Themen 3
B Erkennen, wann Prozess beendet ist, dann Thread beenden. Allgemeine Java-Themen 6
A Thread Fehler absichtlich provozieren Allgemeine Java-Themen 3
B Threads Java Thread kommunizieren Allgemeine Java-Themen 12
N Thread Sicherheit im komplexen Datenmodell Allgemeine Java-Themen 7
K Thread richtig benutzen Allgemeine Java-Themen 3
K Exception in thread "AWT-EventQueue-1" Allgemeine Java-Themen 2
vandread Problem bei kleiner Thread-Übung Allgemeine Java-Themen 2
G Thread erzeugt nicht plausible NullPointerException Allgemeine Java-Themen 7
H Netbeans Warning bei Thread.sleep in Schleife Allgemeine Java-Themen 4
P [Thread] Scheint nicht Sequenziell zu Arbeiten Allgemeine Java-Themen 9
A eine test thread.join() frage Allgemeine Java-Themen 2
tuttle64 Verständnisprobleme mit Thread Locks Allgemeine Java-Themen 4
G Threads Thread bei Datenabfrage Allgemeine Java-Themen 3
S Thread anhalten per Button ? Allgemeine Java-Themen 3
E Thread Programmierung Allgemeine Java-Themen 2
S Threads ServerSocket-Thread soll schlafen, bis er gebraucht wird Allgemeine Java-Themen 2
V Thread schneller stoppen Allgemeine Java-Themen 2
V anstatt thread.join() einfach while schleife? Allgemeine Java-Themen 8
B Mausbewegung im Thread erkennen (hoch/runter) Allgemeine Java-Themen 6
G Linux/C++/Pthreads auf JVM zugreifen, thread safe? Allgemeine Java-Themen 10
K Threads Probleme mit Thread Allgemeine Java-Themen 13
K Threads Thread überprüfen Allgemeine Java-Themen 3
Z Threads Thread für einen Client Allgemeine Java-Themen 9
M Thread JavaFish Allgemeine Java-Themen 10
G Thread.sleep Allgemeine Java-Themen 12
M Threads Viele Aufrufe aus Thread, komisches Verhalten Allgemeine Java-Themen 8
B Threads Main Thread warten auf abgebrochen Task warten lassen Allgemeine Java-Themen 25
K Timer Thread Allgemeine Java-Themen 8
M Methoden Static Methoden und Thread??? Allgemeine Java-Themen 4
N java.lang.IllegalMonitorStateException: object not locked by thread before notify() Allgemeine Java-Themen 2
C Mehothode in anderenm Thread aufrufen Allgemeine Java-Themen 10
R Thread läuft nicht?! Allgemeine Java-Themen 7
R ThreadPool - vorhandene thread liste überprüfen bzw. aufräumen Allgemeine Java-Themen 3
J Anderem Thread Variable mitgeben Allgemeine Java-Themen 2
C Argument an einen Thread übergeben Allgemeine Java-Themen 4
S java.util.ConcurrentModificationException - aber nur ein Thread Allgemeine Java-Themen 3
G JUnit Test Methoden in anderen Thread verlagern Allgemeine Java-Themen 4
P Java Probleme - java.lang.Thread.run(Unkown Source) Allgemeine Java-Themen 10
L Im Thread auf Eingaben warten Allgemeine Java-Themen 3
P aus Thread auf Form zugreifen Allgemeine Java-Themen 9
C Threads Thread blockieren Allgemeine Java-Themen 4
K Threads Thread für Sleep Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben