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