Forum: PC-Programmierung sleep & printf in gcc


von Andi S. (laserandi)


Lesenswert?

Hallo,
ich habe ein Problem mit Zeitverzögerung in C.
Beispiel:
1
#include <stdio.h>
2
#include <unistd.h> //Linux, in Win <sleep.h> (glaube ich)
3
4
int main(){
5
  char test[6] = "Hallo";
6
  int i;
7
  printf("Ausgabe:\n");
8
  for(i=0;i<6;i++){
9
    printf("%c ", test[i]);
10
    sleep(1);
11
  }
12
  printf("\nEnde\n");
13
  return 0;
14
}
Eigentlich sollte mit diesem Programm jeder Buchstabe
in 1s Abständen ausgegeben werden. Tatsächlich wird
aber erst 6s gewartet und dann Hallo ohne Verzögerung
ausgegeben. Warum?

von Karl H. (kbuchegg)


Lesenswert?

Andi S. schrieb:
> Hallo,
> ich habe ein Problem mit Zeitverzögerung in C.
> Beispiel:
1
> #include <stdio.h>
2
> #include <unistd.h> //Linux, in Win <sleep.h> (glaube ich)
3
> 
4
> int main(){
5
>   char test[6] = "Hallo";
6
>   int i;
7
>   printf("Ausgabe:\n");
8
>   for(i=0;i<6;i++){
9
>     printf("%c ", test[i]);
10
>     sleep(1);
11
>   }
12
>   printf("\nEnde\n");
13
>   return 0;
14
> }
> Eigentlich sollte mit diesem Programm jeder Buchstabe
> in 1s Abständen ausgegeben werden. Tatsächlich wird
> aber erst 6s gewartet und dann Hallo ohne Verzögerung
> ausgegeben. Warum?

Weil deine Ausgabe zuerst in einem Buffer landen wird, damit nicht für 
jedes Zeichen die komplette Pipeline bis hinunter zum physikalischen 
Ausgabegerät durchlaufen werden muss, was relativ aufwändig ist. Also 
werden normalerweise mehrere Ausgaben zunächst in einem Buffer gesammelt 
und erst beim Auftreten bestimmter Bedingungen weitergeleitet: Das 
Ausgeben von \n könnte sowas sein.

Man kann allerdings den Ausgabebuffer auch manuell ausleeren lassen
1
    fflush( stdout );

von Andi S. (laserandi)


Lesenswert?

Super, das funktioniert prima.
Danke.

Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.