errno!=eintr
注意read()如果讀到資料為0,那麼就表示檔案結束了,如果在讀的過程中遇到了中斷那麼會返回-1,同時置errno為eintr。
因此判斷read的條件:
如果read返回<=0
如果==0
表示檔案結束, 處理
如果<0 && errno==eintr
表示中斷,處理
否則,出錯
但是write()如果寫入的資料為0,那麼就表示出錯,也就是無法寫入了,而如果在寫的過程中遇到了中斷,那麼write()會返回-1,同時置errno為eintr。
因此判斷write是否成功時,條件是write返回的結果是否<=0
if<=0
if ==0
break;
}ssize_t readn ( int fd, void *vptr, size_t n )
nleft-=nread;
ptr+=nread;
}return ( n-nleft );
}ssize_t writen ( int fd, const void *ptr, size_t n )
nleft-=nwritten;
ptr+=nwritten;
}return (n);
}寫函式write
ssize_t write(int fd,const void *buf,size_t nbytes)
write函式將buf中的nbytes位元組內容寫入檔案描述符fd。成功時返回寫的位元組數,失敗時返回-1,並設定errno變數。
在網路程式中,當我們向套接字檔案描述符寫時有倆種可能:
1) write的返回值大於0,表示寫了部分或者是全部的資料;
2) 返回的值小於0,此時出現了錯誤,我們要根據錯誤型別來處理。
如果錯誤為eintr表示在寫的時候出現了中斷錯誤。如果為epipe表示網路連線出現了問題(對方已經關閉了連線)。
讀函式read
ssize_t read(int fd,void *buf,size_t nbyte)
read函式是負責從fd中讀取內容。當讀成功時,read返回實際所讀的位元組數。如果返回的值是0,表示已經讀到檔案的結束了。小於0表示出現了錯誤。如果錯誤為eintr說明讀是由中斷引起的,如果是econnrest表示網路連線出了問題。
Android Usb獲取以及讀寫
android 6.0 之後提供了storagemanager支援讀寫u盤。有部分是hide方法需要利用下反射,以下記錄下。public static list readusbdevice context context 去除本地目錄 string localpath environment.get...
linux下檢視CPU的總核數以及邏輯核數
總核數 物理cpu個數 x 每顆物理cpu的核數 總邏輯cpu數 物理cpu個數 x 每顆物理cpu的核數 x 超執行緒數 檢視物理cpu個數 cat proc cpuinfo grep physical id sort uniq wc l 檢視每個物理cpu中core的個數 即核數 cat pro...
安裝debian總結以及編譯linux核心
將磁碟進行壓縮操作,並且保留出乙個主分割槽的位置。然後,重新啟動系統按f12,選擇u盤啟動,進行安裝。有幾個需要注意的地方 1 事先在windows系統中,通過 計算機 管理 磁碟管理 的工具,將空閒空間較大的分割槽進行 壓縮盤 操作,我這裡壓縮出40g的空間,再分成兩個partition 乙個用於...