Krain Geschrieben 18. Juli 2002 Geschrieben 18. Juli 2002 Hallo zusammen, Ich hab ein Verständnisproblem bei meinem Programm: import java.util.*; import java.text.*; public class Clock extends Thread { Calendar cal=new GregorianCalendar(); public Clock(int timeHour,int timeMinute,String title) { wakeHour=timeHour; wakeMinute=timeMinute; this.title=title; start(); } public Clock(int timeHour,String title) { this(timeHour,0,title); } public void run() { boolean checked=false; while(true) { try { cal.setTime(new Date()); if (cal.get(Calendar.HOUR_OF_DAY)==wakeHour && cal.get(Calendar.MINUTE)==wakeMinute) { if(!checked) { System.out.println(title); checked=true; } } else { System.out.println(cal.get(Calendar.HOUR_OF_DAY)+":"+ cal.get(Calendar.MINUTE)+" "+cal.getTime()); } Thread.sleep(1000*10); //10 Sekunden warten } catch(InterruptedException e) { System.out.println("interrupted"); } } } private int wakeHour,wakeMinute; private String title; public static void main(String[] args) { Clock clock=new Clock(8,50,"Simpsons kommt"); } } Ich zähle ja eigentlich mit Thread.sleep 10sekundenweise -Wie kann es dann sein, daß das Programm dann bei der Ausgabe(siehe unten rot markiert) von der 7sekunden-Stelle auf die 8sekunden-Stelle umspringt? 8:46 Thu Jul 18 08:46:37 CEST 2002 8:46 Thu Jul 18 08:46:47 CEST 2002 8:46 Thu Jul 18 08:46:57 CEST 2002 8:47 Thu Jul 18 08:47:07 CEST 2002 8:47 Thu Jul 18 08:47:17 CEST 2002 8:47 Thu Jul 18 08:47:27 CEST 2002 8:47 Thu Jul 18 08:47:37 CEST 2002 8:47 Thu Jul 18 08:47:47 CEST 2002 8:47 Thu Jul 18 08:47:57 CEST 2002 8:48 Thu Jul 18 08:48:07 CEST 2002 8:48 Thu Jul 18 08:48:18 CEST 2002 8:48 Thu Jul 18 08:48:28 CEST 2002 8:48 Thu Jul 18 08:48:38 CEST 2002 Zitieren
Klotzkopp Geschrieben 18. Juli 2002 Geschrieben 18. Juli 2002 Original geschrieben von Krain Ich zähle ja eigentlich mit Thread.sleep 10sekundenweise -Wie kann es dann sein, daß das Programm dann bei der Ausgabe(siehe unten rot markiert) von der 7sekunden-Stelle auf die 8sekunden-Stelle umspringt?Weil der Rest des Programms auch Zeit für die Ausführung braucht. Das summiert halt sich mit der Zeit. Zitieren
Jaraz Geschrieben 18. Juli 2002 Geschrieben 18. Juli 2002 Hallo, du zählst nicht 10 Sekundenweise, sondern du schläft jeweils 10 Sekunden. Dazwischen wird allerdings immer ein paar Millisekunden gearbeitet, dadurch kommt irgendwann der Sprung. Wenn du das Programm so weiterlaufen läßt, kommt irgendwann auch der nächste Sprung. Gruß Jaraz Zitieren
T. Schiffler Geschrieben 18. Juli 2002 Geschrieben 18. Juli 2002 Hi Ich kann mir das nur so erklären dass Deine Routine ja auch Rechenzeit verbrät und daher der Offset kommt Erbeere Zitieren
T. Schiffler Geschrieben 18. Juli 2002 Geschrieben 18. Juli 2002 whow 3 antworten innerhalb 1 Minute - neuer Rekord ??? Zitieren
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.