您好,登錄后才能下訂單哦!
這篇文章主要講解了“PHP8.0特性Named Parameter怎么用”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“PHP8.0特性Named Parameter怎么用”吧!
現(xiàn)在的方法原型是:
public static Yar_Concurrent_Client::call(string $uri, string $method, ?array $arguments = NULL, ?callable $callback = NULL, ?callable $error_callback = NULL, ?array $options = NULL):null|int|bool {}
是不是一看就很頭大?
因?yàn)樵趯?shí)際的使用過程中,很有可能回調(diào)函數(shù)和錯(cuò)誤回調(diào)函數(shù)是空的,因?yàn)榭梢哉嬲l(fā)起調(diào)用的時(shí)候,也就是在loop重全局指定:
而很多時(shí)候$options是有用的,根據(jù)調(diào)用相關(guān),所以就導(dǎo)致,實(shí)際的使用的時(shí)候,大量的并行調(diào)用的代碼會(huì)在參數(shù)中寫很多的NULL, 類似: 于是我一直想如何能讓這樣的調(diào)用更優(yōu)雅一些,曾經(jīng)一度我想使用多態(tài),或者新增一個(gè)API,類似: 但強(qiáng)迫癥讓我覺得這樣做,遺禍無窮, 今天早上我突然想起以前曾經(jīng)看到過的一個(gè)RFC,于是找了半天,發(fā)現(xiàn)早在PHP5.6的時(shí)候,就commit了, 但反正我比較老派,新特性研究的少,也是沒怎么用過,就不知道大家是否會(huì)用過了。 ?Yar_Concurrent_Client::loop(?callable $callback = NULL, ?callable $error_callback = NULL, ?array $options = NULL):?bool {}
Yar_Concurrent_Clinet::call("https://xxx.com/api", "method", array("arguments"), NULL, NULL, array(YAR_OPT_HEADER=>array("header:val1"));
Yar_Concurrent_Clinet::call("https://xxx.com/api", "method", array("arguments"), NULL, NULL, array(YAR_OPT_HEADER=>array("header:val2"));
Yar_Concurrent_Clinet::call("https://xxx.com/api", "method", array("arguments"), NULL, NULL, array(YAR_OPT_HEADER=>array("header:val2"));
Yar_Concurrent_Clinet::call("https://xxx.com/api", "method", array("arguments"), NULL, NULL, array(YAR_OPT_HEADER=>array("header:val4"));
public static Yar_Concurrent_Client::callArray(array $arguments):null|int|bool {}
就是今天要介紹的第一個(gè)特性:Argument unpacking。
我們知道PHP支持可變參數(shù),也就是variadic function. 比如對于如下的函數(shù)定義:
注意參數(shù)的定義,使用了三個(gè)點(diǎn)…(ellipsis符號), 意思就是無論你在調(diào)用這個(gè)函數(shù)的時(shí)候傳遞了多少個(gè)參數(shù),這些參數(shù)都會(huì)被打包成一個(gè)名字為$arguments的數(shù)組: 當(dāng)然,這個(gè)不是我們今天要用到的,這個(gè)特性還有一個(gè)對應(yīng)的在調(diào)用時(shí)刻使用的兄弟形式,叫做argument unpacking:function variadic(...$arguments) {
var_dump($arguments);
}
variadic();
//output: array(0) { }
variadic(NULL);
//output: array(1) { [0]=> NULL }
variadic("foo", "bar");
//output: array(2) { [0]=> string(3) "foo" [1]=> string(3) "bar" }
variadic(NULL, array(), "dummy");
//output: array(3) { [0]=> NULL [1]=>[] [2]=> string(5) "dummy" }
比如,類似上面我的那個(gè)問題,我們定義了一個(gè)函數(shù)
如果大部分情況下我們的參數(shù)b, c, d都是NULL, 但是e可能需要傳遞,那我們就可以使用argument unpacking來避免代碼中大量的NULL參數(shù),類似: 注意在調(diào)用的時(shí)候,我也使用了…,這里的意思就是,把…后面的數(shù)組解開,按照順序分別依次傳遞給被調(diào)用的函數(shù),第一個(gè)元素對應(yīng)第一個(gè)參數(shù), 第二個(gè)對應(yīng)第二個(gè)。function dummy($a, $b = NULL, $c = NULL, $d = NULL, $e = NULL) {
var_dump($a, $b, $c, $d, $e);
}
$arguments = array(
"First argument",
NULL, NULL, NULL,
"Fifth argument",
);
dummy(...$arguments);
//output:
// string(14) "First argument"
// NULL
// NULL
// NULL
// string(14) "Fifth argument"
但是注意,這里的位置是跟填充位置相關(guān)的,跟索引無關(guān),也就是說:
這樣的形式, 索引4依然是被認(rèn)為是第一個(gè)參數(shù)。$arguments = array(
4=> "First argument",
0=> "Fifth argument"
),
想到這個(gè)以后,我就突然發(fā)現(xiàn),我不需要給Yar引入新東西了,最開的例子就可以變成:
你以為這就完了么?$arguments = array(
"https://xxx.com/api",
"method",
array("arguments"),
NULL, NULL,
"options" => array(YAR_OPT_HEADER => array("header:val1")
)
Yar_Concurrent_Clinet::call(...$arguments);
$arguments["options"][YAR_OPT_HADER] = ["header:val2"];
Yar_Concurrent_Clinet::call(...$arguments);
$arguments["options"][YAR_OPT_HADER] = ["header:val3"];
Yar_Concurrent_Clinet::call(...$arguments);
$arguments["options"][YAR_OPT_HADER] = ["header:val4"];
Yar_Concurrent_Clinet::call(...$arguments);
Yar_Concurrent_Clinet::call(...$arguments);
考慮到如上的代碼,還是有一個(gè)問題,就是需要構(gòu)造一個(gè)中間數(shù)組,對于強(qiáng)迫癥的我們來說,總還是覺得會(huì)有點(diǎn),那啥…
但其實(shí)我們還可以利用PHP8.0中引入的另外一個(gè)RFC, Named parameter:
在PHP8.0以后,容許用戶在傳遞參數(shù)的時(shí)候,指定參數(shù)名字, 比如還是對于上面的例子函數(shù):
現(xiàn)在我們可以在調(diào)用的時(shí)候,指定要傳遞的參數(shù)名字,比如: 也就是說,我指定了傳遞給a和e參數(shù),沒有指定的就是默認(rèn)缺省值,你甚至可以不按聲明順序來,比如: 輸出結(jié)果也是一樣的。function dummy($a, $b = NULL, $c = NULL, $d = NULL, $e = NULL) {
var_dump($a, $b, $c, $d, $e);
}
dummy(a:"dummy", e:"foo");
//output:
// string(5) "dummy"
// NULL
// NULL
// NULL
// string(3) "foo"
dummy(e:"foo", a:"dummy");
這樣以來,開頭的代碼就可以變成:
Yar_Concurrent_Client::call("https://xxx.com/api", "method", arguments:array("arguments"), options:array(YAR_OPT_HEADER=>array("header:val1")));
Yar_Concurrent_Client::call("https://xxx.com/api", "method", arguments:array("arguments"), options:array(YAR_OPT_HEADER=>array("header:val2")));
Yar_Concurrent_Client::call("https://xxx.com/api", "method", arguments:array("arguments"), options:array(YAR_OPT_HEADER=>array("header:val3")));
Yar_Concurrent_Client::call("https://xxx.com/api", "method", arguments:array("arguments"), options:array(YAR_OPT_HEADER=>array("header:val4")));
感謝各位的閱讀,以上就是“PHP8.0特性Named Parameter怎么用”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對PHP8.0特性Named Parameter怎么用這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。