(PECL eio >= 0.0.1dev)
eio_stat — 取得檔案狀態
eio_stat() 會在 callback 的 result 引數中傳回檔案狀態資訊
path檔案路徑
pri請求的優先順序:EIO_PRI_DEFAULT、EIO_PRI_MIN、EIO_PRI_MAX 或 null。如果傳入 null,則 pri 在內部會設定為 EIO_PRI_DEFAULT。
callback
請求完成時會呼叫 callback 函式。它應該符合以下原型
void callback(mixed $data, int $result[, resource $req]);data傳遞給請求的自訂資料。
result請求特定的結果值;基本上,是相應系統呼叫傳回的值。
req是可選的請求資源,可用於 eio_get_last_error() 等函式。
data傳遞給 callback 的任意變數。
eio_stat() 成功時會傳回請求資源,或在錯誤時傳回 false。成功時,會將 callback 的 result 引數指定為陣列。
範例 #1 eio_stat() 範例
<?php
$tmp_filename = "eio-file.tmp";
touch($tmp_filename);
function my_res_cb($data, $result) {
var_dump($data);
var_dump($result);
}
function my_open_cb($data, $result) {
eio_close($result);
eio_event_loop();
@unlink($data);
}
eio_stat($tmp_filename, EIO_PRI_DEFAULT, "my_res_cb", "eio_stat");
eio_open($tmp_filename, EIO_O_RDONLY, NULL,
EIO_PRI_DEFAULT, "my_open_cb", $tmp_filename);
eio_event_loop();
?>上述範例將輸出類似如下的內容
string(8) "eio_stat"
array(12) {
["st_dev"]=>
int(2050)
["st_ino"]=>
int(2489173)
["st_mode"]=>
int(33188)
["st_nlink"]=>
int(1)
["st_uid"]=>
int(1000)
["st_gid"]=>
int(100)
["st_rdev"]=>
int(0)
["st_blksize"]=>
int(4096)
["st_blocks"]=>
int(0)
["st_atime"]=>
int(1318250380)
["st_mtime"]=>
int(1318250380)
["st_ctime"]=>
int(1318250380)
}