array_filter() 是筛选大于某数元素最直接的PHP原生函数,支持箭头函数(PHP 7.4+),默认保留回调返回true的项;需注意键名处理、索引重置及类型隐式转换问题。
array_filter() 筛选大于某数的元素最直接PHP 原生函数 array_filter() 就是干这事的,不用手写循环。它默认保留回调函数返回 true 的项,天然适合条件筛选。
注意:PHP 7.4+ 支持箭头函数,写法更紧凑;老版本需用匿名函数或单独定义函数。
array_filter($arr, fn($x) => $x > 10)
ARRAY_FILTER_USE_BOTH 标志位array_filter() 不会重排索引 —— 数字键保持原样,想重置用 array_values()
数字索引数组里,筛选后常出现“空洞”(比如原数组 [0=>5, 1=>15, 2=>8, 3=>20] 筛出 >10 得到 [1=>15, 3=>20])。这在 foreach 中没问题,但若后续要按顺序取第 0 个、第 1 个元素就会出错。
array_values(array_filter(...))
['a'=>12, 'b'=>3, 'c'=>18])且想保留语义化键 → 直接用 array_filter(),不加额外处理for 循环遍历结果 → 必须重置索引,否则 $result[0] 可能不存在array_filter()?其实多数情况不必担心有人担心 array_filter() 内部迭代 + 回调调用有开销,想改用 foreach 手动收集。实际测试中,差异仅在数万级元素以上才可能 measurable,且往往被 I/O 或逻辑掩盖。
array_filter() 更清晰表达“我要什么”,而非“我怎么拿”foreach,但别为假想的性能损失提前优化PHP 的松散比较会让字符串数字“混入”判断,比如 '15' 和 15 都满足 > 10,但如果你的数组混合了字符串和整数,又依赖严格类型逻辑,就容易出错。
(int) 或 filter_var($x, FILT
ER_VALIDATE_INT) 预处理=== 不适用(因为是“大于”,不是“等于”),但可在回调里先 cast:fn($x) => (int)$x > 10
[1, '2', 'abc', 15] 筛 >5 → 'abc' 会被转成 0,不满足;但 '10' 会被转成 10,刚好卡在边界上