Heim  >  Artikel  >  Backend-Entwicklung  >  Analyse des Ausgabepuffers der PHP-Flush-Klasse

Analyse des Ausgabepuffers der PHP-Flush-Klasse

高洛峰
高洛峰Original
2016-12-22 16:30:14881Durchsuche

for ($i=10; $i>0; $i--)
{
echo $i;
sleep(); 1);
}
?>
Laut PHP-Handbuch
Diese Funktion sendet alle bisherigen Ausgaben des Programms an den Browser des Benutzers.
Der obige Code sollte jede Sekunde $i ausgeben. Dies ist jedoch in der Praxis nicht unbedingt der Fall. Es ist möglich, dass nach einer Wartezeit von 10 Sekunden alle Ausgaben gleichzeitig angezeigt werden.
Okay, ändern wir diesen Code in
ob_end_clean();//Modify part
for ($i=10; $i>0; $i --)
{
echo $i;
sleep(1);
?> . Tatsächlich ist es auch in Ordnung, wenn wir ob_end_clean() durch ob_end_flush() ersetzen.
Ich werde es wieder ändern.
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush();//Teil ändern
flush();
sleep(1);
}
Führen Sie es aus. Finden Sie, dass $i auch jede Sekunde ausgegeben wird? Warum ist das so?
Keine Sorge, werfen wir einen Blick auf php.ini.
Öffnen Sie php.ini und suchen Sie nach „output_buffering“. Wir sehen eine Einstellung wie diese: „output_buffering = 4096“. Genau wie der Name „output_buffering“ besteht die Funktion dieser Einstellung darin, die Ausgabe zu puffern.
In unserem ersten Codeteil ist der Grund, warum die Ausgabe nicht wie erwartet ist, genau darin, dass „output_buffering“ die Ausgabe puffert Alles gepuffert. Die Ausgabe wird erst gesendet, wenn 4096 Bytes erreicht sind oder das Skript endet.
Die Funktion von ob_end_clean() und ob_end_flush() im zweiten Codeteil besteht darin, die Pufferung zu beenden. Auf diese Weise muss vor dem Versenden nicht gewartet werden, bis ein Puffer von 4096 Byte vorhanden ist.
Im dritten Codeteil wird ob_flush() verwendet. Seine Funktion besteht darin, die gepufferten Daten zu senden, die Pufferung wird jedoch nicht beendet, sodass es vor jedem Flush() verwendet werden muss.
Wenn wir ob_end_clean(), ob_end_flush() und ob_flush() nicht verwenden möchten, müssen wir Output_buffering in php.ini klein genug einstellen, zum Beispiel auf 0 setzen. Es ist zu beachten, dass diese Methode nicht funktioniert, wenn Sie ini_set("output_buffering","0") verwenden möchten, um es in einem Skript festzulegen. Bitte stoppen Sie dies, da diese Methode nicht funktioniert. Denn zu Beginn des Skripts wurden die Pufferungseinstellungen geladen und dann beginnt die Pufferung.
Vielleicht fragen Sie sich, warum Sie „flush()“ verwenden müssen, da ob_flush() die gepufferten Daten sendet? ?
for ($i=10; $i>0; $i--)
{
echo $i;
ob_flush(
sleep(); 1);
}
?> Bitte beachten Sie den Unterschied zwischen ob_flush() undlush(). Ersteres besteht darin, Daten aus dem PHP-Puffer freizugeben, und letzteres besteht darin, Daten, die sich nicht im Puffer befinden oder freigegeben wurden, an den Browser zu senden. Wenn also der Puffer vorhanden ist, müssen wir ob_flush() und Flush() gleichzeitig verwenden.
Ist Flush() hier unverzichtbar? Nein, wir haben eine andere Methode, bei der Daten bei der Ausgabe sofort an den Browser gesendet werden. Die folgenden beiden Codeteile müssen Flush() nicht verwenden. (Wenn Sie „output_buffering“ auf 0 setzen, brauchen Sie nicht einmal ob_flush() und ob_end_clean())
ob_implicit_flush(true); for ($i=10; $ i> 0; $i--)
echo $i;
sleep(1);
<
ob_end_clean();
ob_implicit_flush(true);
for ($i=10; $i>0; $i--)
{
echo $i; (1);
}
?> Bitte beachten Sie ob_implicit_flush(true) oben. Diese Funktion erzwingt, dass die Ausgabe sofort an den Browser gesendet wird. Auf diese Weise ist es nicht erforderlich, Flush() zu verwenden, um es nach jeder Ausgabe (Echo) an den Browser zu senden.
Die obige Beschwerde trifft bei manchen Browsern möglicherweise nicht zu. Denn auch Browser haben ihre eigenen Regeln. Zum Testen habe ich Firefox 1.5, IE6 und Opera 8.5 verwendet. Unter anderem kann Opera nicht normal ausgeben, da es die Regel hat, dass es nie ausgegeben wird, wenn es nicht auf ein HTML-Tag stößt, es sei denn, das Skript wird beendet. Firefox und IE sind relativ normal.
Schließlich ist ein sehr interessanter Code angehängt, geschrieben von PuTTYshell. In einem Skriptzyklus überschreibt jede Ausgabe die vorherige Ausgabe.
Der folgende Code ist nur unter Firefox verfügbar. Andere Browser unterstützen den Content-Type von multipart/x-mixed-replace nicht - Mixed-replace;boundary=endofsection');
print "n--endofsectionn"
$pmt = array("-", "\", "|", "/" ); for ( $i = 0; $i <10; $i ++ ){
sleep(1);print „Part $it“.$pmt[$i % 4];
print „--endofsectionn“;
flush(); -type: text/plainnn";
print "The endn";
print "--endofsection--n";
?>



Weitere Artikel zur PHP-Flush-Ausgabepufferanalyse finden Sie auf der chinesischen PHP-Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn