Linux系統庫函數 — lseek函數用法

來源:互聯網
上載者:User

所有開啟的檔案都有一個當前檔案位移量(current file offset),以下簡稱為 cfo。cfo 通常是一個非負整數,用於表明檔案開始處到檔案當前位置的位元組數。讀寫操作通常開始於 cfo,並且使 cfo 增大,增量為讀寫的位元組數。檔案被開啟時,cfo 會被初始化為 0,除非使用了 O_APPEND 。

    使用 lseek 函數可以改變檔案的 cfo 。

        #include

        off_t lseek(int filedes, off_t offset, int whence);

                    傳回值:新的位移量(成功),-1(失敗)

參數 offset 的含義取決於參數 whence:

    1. 如果 whence 是 SEEK_SET,檔案位移量將被設定為 offset。
    2. 如果 whence 是 SEEK_CUR,檔案位移量將被設定為 cfo 加上 offset,
       offset 可以為正也可以為負。
    3. 如果 whence 是 SEEK_END,檔案位移量將被設定為檔案長度加上 offset,
       offset 可以為正也可以為負。

SEEK_SET、SEEK_CUR 和 SEEK_END 是 System V 引入的,在這之前使用的是 0、1 和 2。

    lseek 的以下用法返回當前的位移量:

        off_t    currpos;
        currpos = lseek(fd, 0, SEEK_CUR);

這個技巧也可用於判斷我們是否可以改變某個檔案的位移量。如果參數 fd(檔案描述符)指定的是 pipe(管道)、FIFO 或者 socket,lseek 返回 -1 並且置 errno 為 ESPIPE。

    對於普通檔案(regular file),cfo 是一個非負整數。但對於特殊裝置,cfo 有可能是負數。因此,我們不能簡單地測試 lseek 的傳回值是否小於 0 來判斷 lseek 成功與否,而應該測試 lseek 的傳回值是否等於 -1 來判斷 lseek 成功與否。

    lseek 僅將 cfo 儲存於核心中,不會導致任何 I/O 操作。這個 cfo 將被用於之後的讀寫操作。

    如果 offset 比檔案的當前長度更大,下一個寫操作就會把檔案“撐大(extend)”。這就是所謂的在檔案裡創造“空洞(hole)”。沒有被實際寫入檔案的所有位元組由重複的 0 表示。空洞是否佔用硬碟空間是由檔案系統(file system)決定的。

原文:http://hi.baidu.com/%CE%DAѻ%C3%F7/blog/item/7ac5cc430b45501673f05d00.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.