Thread.sleep() ungenau???

Status
Nicht offen für weitere Antworten.

pocketom

Bekanntes Mitglied
Das ist wohl eine Problem für die Profis hier:

Gerade ist mir aufgefallen dass Thread.sleep(1); nicht das geünschte Ergebnis liefert, statt 1 ms wartet der Thread ca. 30ms, bei mehrmaliger Ausführung hintereinander nähert man sich dann im Schnitt langsam an. Auch sleep(0,1) unter Zuhilfename der Nanosekunden schafft da keine Abhilfe, weswegen sich mir im Moment grad nicht erschliesst wieso ich Nanosekunden hier überhaupt einsetzen kann?

Folgendes Beispiel verdeutlicht es:
Java:
public class Test {

	/**
	 * @param args
	 * @throws InterruptedException 
	 */
	public static void main(String[] args) throws InterruptedException {

		long millis = 100;
		
		
		long start = System.currentTimeMillis();
		for(int i=0;i<millis; i++)
		{
			Thread.sleep(1);
		}
		long end = System.currentTimeMillis();	
		
		System.out.println("TIME: "+(end-start));
	}
}

Was tun wenn ich also nur eine kurze und möglichst exakte Wartezeit von ~1-2 ms haben will?
 

Wildcard

Top Contributor
Was tun wenn ich also nur eine kurze und möglichst exakte Wartezeit von ~1-2 ms haben will?
Geht so nicht, dafür löst der Scheduler des Betriebssystems das nicht genau genug auf.
Kurz Warten geht mit yield, lang warten geht mit sleep. Dazwischen gibt's nur busy waiting, oder die Kombination aus busy waiting und sleep wenn es nichts ausmacht das ein yield auch mal länger dauern kann als 1ms. Warum willst du überhaupt so kurz Schlafen und das auch noch exakt?
 

pocketom

Bekanntes Mitglied
Ich arbeite gerade mit iText an der automatischen Erstellung von PDF Dokumenten. Leider läuft da irgendetwas nicht synchron, ich erstelle in einer Schleife einen Funktionsgraphen und füge danach eine neue Seite ein. Leider habe ich auf vielen Seiten dieselbe Abbildung obwohl jedesmal etwas anderes zu sehen sein sollte. Füge ich in die Schleife ein sleep(1) ein gehts, aber bremst auch (zu) stark... Wäre natürlich schöner das Problem an der Wurzel anzupacken, aber ich habe einfach keine Ahnung was da schief läuft...
 

Wildcard

Top Contributor
Nun, du wirst nicht unhinkommen das Problem doch an der Wurzel anzupacken, denn sonst kommst du von 'funktioniert meistens nicht' zu 'funktioniert beim Kunden nicht mehr' und das ist eigentlich schlimmer als vorher (ohne das sleep)
 

Schandro

Top Contributor
Auch sleep(0,1) unter Zuhilfename der Nanosekunden schafft da keine Abhilfe, weswegen sich mir im Moment grad nicht erschliesst wieso ich Nanosekunden hier überhaupt einsetzen kann?
Hier mal der Code von sleep mit nanosekunden, ich denke das sagt alles...
Java:
    public static void sleep(long millis, int nanos) 
    throws InterruptedException {
	if (millis < 0) {
            throw new IllegalArgumentException("timeout value is negative");
	}

	if (nanos < 0 || nanos > 999999) {
            throw new IllegalArgumentException(
				"nanosecond timeout value out of range");
	}

	if (nanos >= 500000 || (nanos != 0 && millis == 0)) {
	    millis++;
	}

	sleep(millis);
    }
Aber wie bereits gesagt wurde läuft sleep eh im Millisekundenbereich ungenau.
 

pocketom

Bekanntes Mitglied
Naja, ich habe zum Glück mittlerweile die Ursache finden können, ein falsch initialisierter Randomizer war schuld.... Ich habe den nun in die Schleife hineingepackt und seede mit Zeit+Schleifenindex. Kaum macht mans richtig schon gehts auch :)
 

Wildcard

Top Contributor
Naja, ich habe zum Glück mittlerweile die Ursache finden können, ein falsch initialisierter Randomizer war schuld.... Ich habe den nun in die Schleife hineingepackt und seede mit Zeit+Schleifenindex. Kaum macht mans richtig schon gehts auch :)

Und ist das nicht auch viel besser als sinnlos zu schlafen? ;)
 

Saxony

Top Contributor
Hiho,

Stichworte in diesem Zusammenhang sind:

- Zeitscheibe
- Präemptives Multitasking

Für WinNT beispielsweise waren es 10ms - also jeder Thread.sleep(0..10) Aufruf dauert also mind. 10ms unter WinNT.

Das Einzige was in einem Rechner wirklich in ns gemessen wird und auch so arbeitet sind die Schaltzeiten von Arbeitsspeicher.

bye Saxony
 
Zuletzt bearbeitet:

Saxony

Top Contributor
Java:
	if (nanos >= 500000 || (nanos != 0 && millis == 0)) {
	    millis++;
	}

	sleep(millis);
    }

LoL - schon tricky die Java Entwickler! Bei denen sind also schon 500k ns eine ms wert. Im Umkehrschluss allerdings ist ein Wert von 499.999 ns nicht beachtenswert ausser die ms sind 0 dann wird selbst eine ns schon zu einer ms. :toll:

Naja was wollen se sonst machen - selbst 1ms ist viel zu fix für den OS Scheduler.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Thread.sleep Problem Allgemeine Java-Themen 2
B Thread.sleep() in EJB Container wie lösen? Allgemeine Java-Themen 11
mrbig2017 Sleep wird ignoriert und der Thread wartet nicht Allgemeine Java-Themen 1
W Thread sleep 30 sekunden - wenn keine Antwort bis dahin neu senden Allgemeine Java-Themen 2
V Thread.sleep und InterruptedException? Allgemeine Java-Themen 1
H Netbeans Warning bei Thread.sleep in Schleife Allgemeine Java-Themen 4
G Thread.sleep Allgemeine Java-Themen 12
K Threads Thread für Sleep Allgemeine Java-Themen 6
C Thread.sleep pausiert das ganze Programm Allgemeine Java-Themen 4
hdi volatile & Thread#sleep/yield - Versteh ich nich Allgemeine Java-Themen 14
V Enerjy und Use of Thread.sleep() Allgemeine Java-Themen 2
thE_29 Thread sleep Bug Allgemeine Java-Themen 26
Schandro Thread.sleep(0) Allgemeine Java-Themen 6
J Was ist genauer: Thread.sleep() oder meine Variante? Allgemeine Java-Themen 64
padde479 The static method sleep(long) from the type Thread should. Allgemeine Java-Themen 2
R Thread.sleep - abfragen Allgemeine Java-Themen 4
T Ersatz für Thread.sleep Allgemeine Java-Themen 8
T Frage zu Thread.sleep() Allgemeine Java-Themen 2
G Thread.currentThread().sleep() und Thread.sleep() Allgemeine Java-Themen 2
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
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
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
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
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
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
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
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

Ähnliche Java Themen

Neue Themen


Oben