- 相關(guān)推薦
php的obFlush與Flush使用方法
有關(guān)php的ob_flush()與flush()使用方法
注意:ob_flush()和flush()這兩個函數(shù)一般要一起使用,順序是先ob_flush(),然后flush(),它們的作用是刷新緩沖區(qū)。
這里具體的說下什么時候要用到刷新緩沖區(qū)和為什么要刷新緩沖區(qū)。
一、什么時候要刷新緩沖區(qū)
當(dāng)程序中用到file_get_contents()和file_put_contens()這兩個函數(shù)時,或程序中執(zhí)行類似的“讀寫”功能或向瀏覽器執(zhí)行輸出操作時,會用到ob_flush()和flush()來刷新緩沖區(qū)。
二、為什么要刷新緩沖區(qū)
用file_get_contents()和file_put_content()為例進行講解。
file_get_contents()和file_put_conents()這兩個函數(shù)分別執(zhí)行讀取數(shù)據(jù)和寫入數(shù)據(jù)操作,數(shù)據(jù)是先被讀到內(nèi)存中然后在寫入文件中的,因為讀取的速度比寫入的速度要快,所以當(dāng)你的數(shù)據(jù)被讀完的時候不代表數(shù)據(jù)也寫入完畢,這個時候多讀的內(nèi)容就會被暫時放到緩沖區(qū)中(內(nèi)存),在這里需要強調(diào)一下,其實數(shù)據(jù)讀取和寫入是兩個非常快的動作哦。
還用一種解釋(當(dāng)程序向瀏覽器執(zhí)行輸出操作時),個別web服務(wù)器程序,特別是Win32下的web服務(wù)器程序,在發(fā)送結(jié)果到瀏覽器之前,仍然會緩存腳本的輸出,直到程序結(jié)束為止。如果你不想讓程序執(zhí)行完畢才向瀏器輸出,那么你也可以用到ob_flush()和flush()來刷新緩存。
其實,flush()還有一種用途,就是在沒結(jié)束程序之前就進行輸出,即一個循環(huán)還沒結(jié)束就可以把部分結(jié)果輸出到瀏覽器上,這個效果很類似 ajax的異步傳輸效果。
深入理解ob_flush和flush的區(qū)別
ob_flush/flush在手冊中的描述, 都是刷新輸出緩沖區(qū), 并且還需要配套使用, 所以會導(dǎo)致很多人迷惑…
其實, 他們倆的操作對象不同, 有些情況下, flush根本不做什么事情。。
ob_*系列函數(shù), 是操作PHP本身的輸出緩沖區(qū)。
所以, ob_flush是刷新PHP自身的緩沖區(qū)。
而flush, 嚴格來講, 這個只有在PHP做為apache的Module(handler或者filter)安裝的時候, 才有實際作用。 它是刷新WebServer(可以認為特指apache)的緩沖區(qū)。
在apache module的sapi下, flush會通過調(diào)用sapi_module的flush成員函數(shù)指針, 間接的調(diào)用apache的api: ap_rflush刷新apache的輸出緩沖區(qū), 當(dāng)然手冊中也說了, 有一些apache的其他模塊, 可能會改變這個動作的結(jié)果。。
有些Apache的模塊,比如mod_gzip,可能自己進行輸出緩存,這將導(dǎo)致flush()函數(shù)產(chǎn)生的結(jié)果不會立即被發(fā)送到客戶端瀏覽器。
甚至瀏覽器也會在顯示之前,緩存接收到的內(nèi)容。例如 Netscape瀏覽器會在接受到換行或 html 標(biāo)記的開頭之前緩存內(nèi)容,并且在接受到標(biāo)記之前,不會顯示出整個表格。
一些版本的 Microsoft Internet Explorer 只有當(dāng)接受到的256個字節(jié)以后才開始顯示該頁面,所以必須發(fā)送一些額外的空格來讓這些瀏覽器顯示頁面內(nèi)容所以, 正確使用倆者的順序是。 先ob_flush, 然后flush,
當(dāng)然, 在其他sapi下, 不調(diào)用flush也可以, 只不過為了保證你代碼的可移植性, 建議配套使用。
【php的obFlush與Flush使用方法】相關(guān)文章:
php實習(xí)心得12-01
php實習(xí)報告11-07
php工作總結(jié)11-11
php是什么格式?01-14
PHP Socket編程過程02-09
php開發(fā)主管的職責(zé)05-15
早教機使用方法10-24
php開發(fā)主管的工作職責(zé)09-29
php實習(xí)報告(5篇)11-08
php實習(xí)心得7篇12-02