您好,登錄后才能下訂單哦!
這篇文章主要介紹“分析web緩沖問題”,在日常操作中,相信很多人在分析web緩沖問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”分析web緩沖問題”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
更改緩沖類型
在上一篇中說到了一些默認的緩沖類型,例如:
指向終端設備的流是行緩沖的
標準錯誤是不帶緩沖的
指向文件的流是全緩沖的
……
那么這些默認的緩沖類型如何修改?有幾個函數可以用來更改緩沖類型:
#include<stdio.h> void setbuf(FILE *stream, char *buf); void setbuffer(FILE *stream, char *buf, size_t size); void setlinebuf(FILE *stream); int setvbuf(FILE *stream,char *buf, int mode, size_t size);
參數說明如下:
stream FILE *類型,文件指針
buf 緩沖區指針
mode 緩沖模式,包括_IOFBF(全緩沖),_IOLBF(行緩沖),_IONBF(不帶緩沖)
size 緩沖區大小
這里有四個相關函數,作用類似,只是修改范圍不一。
setbuf函數中,如果buf設置為NULL,則緩沖關閉;否則指向長度為BUFSIZ長度的緩沖區,并且是行緩沖。
#include<stdio.h> #include<unistd.h> int main(void) { setbuf(stdout,NULL); printf("bianchengzhuji"); sleep(10); return 0; }
這里設置為不帶緩沖,則會忽略buf和size參數。設置為全緩沖或者行緩沖的時候。并且buf為NULL,會使用合適長度的系統buffer,否則使用用戶自定義buffer。緩沖區的設置就介紹到這里。
fputs沒有及時輸出
其實在有了前面的基礎之后,很多問題就迎刃而解了。
看看下面的例子:
#include<stdio.h> #include<unistd.h> int main(void) { //setbuf(stdout,NULL); fputc('a',stdout); sleep(10); return 0; }
比如你就想輸出一個字符,就打印到終端,但是按照上面的方法,字符并不會被及時輸出到終端,因此它默認是行緩沖的。打開注釋行,設置為不帶緩沖就可以了。
printf打印的日志沒有輸出
不知道你有沒有遇到過這樣的情況,準備調試某一個bug,發現每次運行到某個地方,打印就結束了,然后就掛了,讓你誤以為程序執行到打印的地方就結束了,然而有可能程序執行到后面,只是由于打印是行緩沖的,導致部分打印沒有出來,很可能就是你沒有加上換行符打印而已。
這時候你可以設置為不帶緩沖,或者關鍵位置fflush,或者打印記得加上換行符。
fflush之后文件還是丟失了
看完前面的內容之后,是不是覺得豁然開朗了?別高興的太早。
以上措施并不是萬事大吉。
你可能會踩到什么坑?
文件內容寫完后,fflush了,內容也有了,然后完成后,系統馬上復位,復位起來后,文件內容還是丟失了
解壓一個壓縮包,解壓成功,系統復位后,還是發現文件大小為0,文件丟失了
如果你目前還沒有遇到過這樣的問題,那么你就需要格外注意了。雖然前面fflush等措施將緩沖區的內容進行了I/O操作,但是操作系統還需要將文件系統的buffer寫入磁盤,因此馬上直接復位會導致文件丟失!怎么辦呢?可以使用:
fsync/sync函數
sync命令
到此,關于“分析web緩沖問題”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。