色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

淺談PHP 閉包特性在實際應(yīng)用中的問題

呃,其實大部分情況下是可以的,而有些方面還是令人非常的困擾,下面慢慢道來。
很多語言的都提供了非常優(yōu)雅和漂亮的操作數(shù)組的方法。在下面的例子中,會使用 php5.3 以及其他語言提供的閉包功能,用于展示如何“客觀的”操作迭代數(shù)組。
譯注:原文作者比較火星,我不了解 Groovy 以及 Scala 語言,所以這里我加上 Javascript 的實現(xiàn)。
在開始之前先說明下,本例子僅僅是闡明觀點,并沒有考慮性能等其他方面的因素。

“貨比三家”

用個簡單的例子開始,有下面?zhèn)€數(shù)組:
$nums = array(10, 20, 30, 40);需要找出數(shù)組中大于 15 的項。那么,不考慮閉包的情況下,我們或許會這樣寫:
$res = array();foreach ($nums as $n) { if ($n > 15) { $res[] = $n; }}如果語言本身有閉包支持的,那么或許會這樣寫(Groovy 語言)
def res = nums.findAll { it > 15 }或者使用 Scala 語言
val res = nums filter (_ > 15)譯注:Javascript 1.6 的話會是如下
var res = nums.filter(function(c){return c > 15});因為循環(huán)操作已被抽象起來,所以可以看到 GroovyScala (以及 Javascript) 都很漂亮得用一行就可以搞定。
當然,如果使用 php5.3 的閉包,也可以做到
$res = array_filter($nums, function($v) { return $v > 15; });php 在這方面使用了比 Scala 更多的字符,但對比先前的例子,它更簡短并且能更好得閱讀。

順便說下,上面的 php 代碼實際上是使用了 Lambda 解析式,并不是個真正的閉包,這個 并不是我們目前關(guān)注的重點。詳細闡述 php 閉包以及 Lambda 解析式的資料,可以參考這里。
目前看來感覺都還不錯,那么我們再的題目增加點難度:找到所有大于 15 的項, 然后乘以 2 再加上作用域中的的某個變量值以后再返回。

Groovy 的實現(xiàn):
def x = 1def res = nums .findAll { it > 15 } .collect { it * 2 + x }Scala 的實現(xiàn):
val x = 1val res = nums filter (_ > 15) map (_ * 2 + x)譯注,Javascript 的實現(xiàn):
var i = 1;var res = nums.filter(function(c){return c > 15}).map(function(c){return c * 2 + i});以及 php
$x = 1;$res = array_map( function($v) use ($x) { return $v * 2 + $x; }, array_filter( $nums, function($v) { return $v > 15; }));光從代碼量方面,現(xiàn)在看起來 php 與其他語言有出入了。先拋開代碼字面上本身 的審美不談,上面的 php 代碼還有個額外的問題。
例如,如果需要使用數(shù)組的鍵而非值作比較,怎么辦?是的,上面的代碼就辦不到了。同時,從語法角度上說,上面的代碼非常難以閱讀。

返璞歸真,這時還是得返回老土的思路去解決問題:
$x = 1;$res = array();foreach ($nums as $n) { if ($n > 15) { $res[] = $n * 2 + $x; }}呼,這樣看起來又很清楚了。但這個時候你或許又會迷惑了:“那還瞎折騰啥,這不就是個數(shù)組操作嗎?”。
是的,好戲還在后頭。這個時候該讓 php 的某些高級特性出場,來搞定這看似有自殘傾向 的“無聊問題”。

ArrayObject 主站蜘蛛池模板: 渭南市| 黄陵县| 沂南县| 仁寿县| 苏州市| 偃师市| 诸城市| 磐石市| 淮南市| 喀什市| 隆子县| 浦北县| 通辽市| 大足县| 宁安市| 新田县| 调兵山市| 资阳市| 云和县| 桑植县| 瓮安县| 盱眙县| 湖州市| 津市市| 揭西县| 淳安县| 团风县| 湘乡市| 太和县| 盐山县| 江华| 南丹县| 永定县| 西藏| 岳阳县| 宝应县| 贵南县| 缙云县| 咸丰县| 屏东市| 泰顺县|