(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)