// $stream = fread($handle, $length);//從檔案當前指標位置,往後讀取n個位元組長度
//重置檔案指標的位置。指定指標的位置,指標位置修改後。讀取檔案,後面是從這個位置開始讀取了
//fseek($handle,105);
//fgets表示每次讀取檔案的一行
$error_log_array = ;
while( ($line = fgets($handle) ) !==false)
}fclose($handle);
需要注意的幾個點:
1、如果是使用fwrite,注意避免將原來檔案的內容清空掉了。關鍵是fopen的開啟方式。r或者w。
如果使用追加方式則是a標記。
2、fopen的時候,注意判斷是否成功開啟檔案。避免使用feof的時候進入死迴圈。因為這個函式,當傳入進去不是指標,則這個函式永遠會返回false
feof的本意是:判斷是否為檔案結尾。如果是結尾,則返回true。不是結尾返回false。如果恰好傳入非法的指標,那麼永遠不是檔案結尾了,一直返回
false。
feof()函式,當傳入進去的不是指標型別的時候,使用如下判斷會出現死迴圈
while(!feof($fp)){
3、fread和fgets。讀取檔案一行一行讀取,則使用fgets。不是按照行讀取,則使用fread()讀取。
要注意這一點細節:如果沒有更多的內容,則返回false,也就是兩種情況,如果裡面的內容為空。也會返回false。當讀取到檔案的結尾的時候,這兩個函式也是返回false(難怪我們使用feof()使得我們不會發現這個細節,因為這個函式已經幫助我們判斷檔案結尾了)
4、使用追加方式(即a標記)開啟檔案,要注意,這種方式下,無法讀取檔案內容的,只能往裡面寫入檔案。所以針對這個控制代碼進行fread()是會得到false的
總結是,如果只是僅僅讀取檔案的內容,就只用讀的方式開啟,如果是寫入新內容進去,則用a的方式開啟
現在明白,為什麼要分多種模式進行區分了。以前覺得沒有用。現在看來,開啟的檔案方式決定了,你能夠針對檔案做什麼(新增新內容還是讀取內容。)
c 分割字串 類似於boost split
由於c 字串沒有split函式,所以字串分割單詞的時候必須自己手寫,也相當於自己實現乙個split函式吧!如果需要根據單一字元分割單詞,直接用getline讀取就好了,很簡單 1 include 2 include 3 include 4 include 5 using namespace std ...
c 類似於千千靜聽的桌面停靠程式
c 類似於千千靜聽的桌面停靠程式 using system using system.collections.generic using system.componentmodel using system.data using system.drawing using system.linq us...
C 實現延遲方法類似於JS的settimeout
我們在變成過程中經常使用非同步或者延遲處理,指令碼中有現成的延遲處理settimeout,但是在c 後端中就沒有這樣現成的方法,但是我們可以使用times可以做乙個類似的方法 如下1000為延遲時間,時間單位為毫秒,而actionfunction則為具體的活動方法,在裡面寫入方法後就可以實現非同步呼...