(PECL eio >= 0.0.1dev)
eio_custom — 像任何其他 eio_* 呼叫一樣執行自訂請求
eio_custom() 會執行由 execute 指定的自訂函式,其處理方式與任何其他 eio_* 呼叫相同。
execute指定應符合以下原型之請求函式
mixed execute(mixed data);
callback 是事件完成回呼,應符合以下原型 void callback(mixed data, mixed result);
data 是未經修改即透過 data 參數傳遞給 execute 的資料,result 值則是由 execute 返回。
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_custom() 成功時返回請求資源,失敗時返回 false。
範例 #1 eio_custom() 範例
<?php
/* 自訂回呼的回呼函式 */
function my_custom_callback($data, $result) {
var_dump($data);
var_dump(count($result));
var_dump($result['data_modified']);
var_dump($result['result']);
}
/* 自訂請求 */
function my_custom($data) {
var_dump($data);
$result = array(
'result' => 1001,
'data_modified' => "my custom data",
);
return $result;
}
$data = "my_custom_data";
$req = eio_custom("my_custom", EIO_PRI_DEFAULT, "my_custom_callback", $data);
var_dump($req);
eio_event_loop();
?>上述範例將輸出類似以下的內容
resource(4) of type (EIO Request Descriptor) string(14) "my_custom_data" string(14) "my_custom_data" int(2) string(14) "my custom data" int(1001)